2013-03-24 160 views
0

这是一个非常复杂的代码,但是忍受着我。在循环中使用调用函数

此代码用于检查回文。我遇到的问题是不知道如何从另一个函数和循环中调用函数。

这是有问题的行:

if (new_num != rev) 
    { 
     while (higher != calc_reverse(higher) && lower != calc_reverse(lower)) 
    { 
     higher = calc_reverse(number++); 
     lower = calc_reverse(number--); 
    } 

下面是我的程序,它参与了错误下半年的代码。 当我使用这个我只是得到“rev(数字)”打印在一个无限循环,直到我强制结束代码。

//Function Declaration 
int calc_reverse(int new_num) 
{ 
//Local Declarations 
    int count = 0; // number of digits in the number 
    int rev = 0; //the reverse of the number 
    int last; //the last digit of the number 

//Calulations 
    while (new_num > 0) 
    { 
    last = new_num % 10; 
    rev = last + (rev * pow(10, count)); 
    new_num = new_num/10; 
    count++; 
    } 
    printf("rev %d \n", rev); 
    fflush(stdout); 
    return(rev); 
} 

//function Decleration 
void calc_closest(int count, int new_num, int rev, int number) 
{ 
//Local declerations 
    int higher = 12; //the higher palindrome 
    int lower = 12; // the lower palindrome 

    printf(" %d, %d \n", new_num, rev); 
    fflush(stdout); 
//Calculations 
    if (new_num == rev) 
    { 
     printf("The value input (%d) is a compact palindrome. \n", number); 
    } 

    if (new_num != rev) 
    { 
     while (higher != calc_reverse(higher) && lower != calc_reverse(lower)) 
    { 
     higher = calc_reverse(number++); 
     lower = calc_reverse(number--); 
    } 
    if (higher == new_num && lower == new_num) 
    { 
     printf("Closest palindromes to %d are: %d, %d \n", number, lower, higher); 
    } 
    else if(higher == new_num) 
    { 
     printf("Closest palindromes to %d are: %d \n", number, higher); 
    } 
    else if (lower == new_num) 
    { 
     printf("Closest palindromes to %d are: %d \n", number, lower); 
    } 
    } 
    return; 
} 

回答

1

您正在使用同一个变量“number”来统计up(number ++)和down(number--)。

这是行不通的。当你添加一个,然后减去一个,你剩下的开始的数字相同,让你陷入无限循环。

您将需要使用两个单独的变量。

或者,您可以只使用一个升序计数器,从中计算较高的数字和较低的数字。例如:i = 0,1,2,3 ...,更高:数字+ i,更低:数字-i。这里的“数字”永远不会改变初始值。

+0

好吧我认为这是有效的,我只需要调整代码早期发生的一些事情(主要是相反的功能,因为它似乎并不总是工作)。一旦我修复了这些部分,我会让你知道。谢谢您的帮助!!! – 2013-03-24 22:58:23