My code is causing a segmentation fault when accessing an array element even though that element was already accessed without a problem.
int charToInt(char a)
{
int b;
if(isdigit(a))
{
b = a - '0' - 1;
}
if(isalpha(a))
{
b = a - 65;
}
return b;
}
int validPosition(char **array, int r, int c, char* position, int slots)
{
int i,k;
if(strlen(position) == 5)
{
if(!isalpha(position[0]) || !isdigit(position[1]) || position[2]!=' ' || (position[3]!='N' && position[3]!='E' && position[3]!='W' && position[3]!='S')) //lathos gramma
{
printf("\n%s", "Invalid answear.This is an example of a valid answear: A5 N");
return 2;
}
if( charToInt(position[0]) > r - 1 || charToInt(position[1]) > c - 1 )//ama vgainei eksw apo ta oria
{
printf("\n%s", "The position you choosed is out of the bountries...");
return 2;
}
printf("\n%s%c%s","position[3] is: ",position[3], " but it doesn't work >_<"); // position[3] is N
if(position[3] == 'N') //the problem is here <~~~~~~~~~~~~~~~~~~~<
{
printf("\n%s", "come on");
if(charToInt(position[0]) + slots < r)
{
for(i=charToInt(position[0])-1; i<charToInt(position[0])+slots; i++)
{
if(array[i-1][charToInt(position[1])-1] != '.')
{
printf("\n%s", "The position you choosed is not valid because there is oneother ship there");
return 2;
}
}
}
else
{
printf("\n%s", "The ship is going out of the bountries...");
return 2;
}
}
}
}
When position holds the string "A9 N", the printf correctly outputs 'N' for position[3]. For some reason when it tries to do if(position[3] == 'N'), however, a segmentation fault occurs.
Example program run:
Example of positioning: G3 E Aircraft carrier (5 places), Give location and direction: A9 N 1 position[3] is: N but it doesn't work >_<
printf("\n%s", "come on");doesn't appear to run. How is this function called? How are its parameters obtained? What does the definition ofcharToIntlook like? My guess is the problem is actually related to the access toarrayinstead ofposition.ivariable provides a nice little value that is bigger or equal to1, otherwise you are in deep drouble with your code.charToIntfunction, how does that look? (There is a stdlib function otherwise calledatoiwhich stands for ascii to int).Aasposition[0], thencharToInt(position[0])will return0. So first run in the for loop makesi = 0 - 1 equaling that i == -1and for that loop you try to accessarray[i - 1]; <-- BAM error. Cant access array[-2], thats a negative array index and is not allowed.