我試圖編寫用於測試字符串的程序,如果它是迴文或不是,但我總是得到輸出,因爲它不是一個。我的代碼有什麼問題?在C中使用遞歸函數的迴文測試
#include <stdio.h>
#include <string.h>
int is_palindrome(int start, int end, char *str)
{
if (str[start] != str[end])
return 0;
else if (start == end)
return 1;
else
return is_palindrome(++start, --end, str);
return 0;
}
int main()
{
char str[20];
int length,start=0,end=length-1;
int result;
printf("Enter the String.\n");
fgets(str, sizeof(str), stdin);
length = strlen(str);
if(is_palindrome(start,end,str))
printf("It's a palindrome!\n");
else
printf("It's not a palindrome! \n");
return 0;
}
逐行掃描調試器中的代碼。並且使用一個你知道的字符串是一個迴文,最好是一個短的字符串,因此它更快。 –
'int length,start = 0,end = length-1;'長度在這裏沒有值(尚)。 – wildplasser
'length'沒有設置任何東西,因此'end'是垃圾。 – eduffy