qq_45735316
2020-05-11 21:16
采纳率: 80.7%
浏览 163

为什么没有输出结果?代码是哪里错了?

//1. 寻找并输出11~999之间的数m,它满足m、m^2和m^3均为回文数。


#include <iostream>
using namespace std;
int ispalindrome(int i)                            //判断i是否为回文数
{
    int n = 0;
    int k = i;
    int flag = 1;
    while (k)
    {
        k /= 10;
        n++;
    }
    int* a = new int[n];
    for (int j = n; j >= 0; j--)
    {
        a[j] = i % 10;
        i /= 10;
    }
    for (int j = 0; j <= n; j++)
    {
        if (a[j] != a[n - j])
        {
            flag = 0;
            break;
        }
    }
    return flag;
}
int main()
{
    int i = 11;
    for (int i = 11; i <= 99; i++)
    {
        if (ispalindrome(i))
        {
            if (ispalindrome(i * i))
            {
                if (ispalindrome(i * i * i))
                {
                    cout << i << endl;
                }
            }
        }
    }
    return 0;
}
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • blownewbee 2020-05-11 23:32
    已采纳

    回文数的判断有问题

    #include <iostream>
    using namespace std;
    int ispalindrome(int i)                            //判断i是否为回文数
    {
        int re = 0;
        int i1 = i;
        while (i1 != 0)
        {
            re *= 10;
            re = re + i1 % 10;
            i1 /= 10;
        }
        return re == i;
    }
    int main()
    {
        int i = 11;
        for (int i = 11; i <= 999; i++)
        {
            if (ispalindrome(i))
            {
                if (ispalindrome(i * i))
                {
                    if (ispalindrome(i * i * i))
                    {
                        cout << i << endl;
                    }
                }
            }
        }
        return 0;
    }
    

    11
    101
    111
    Press any key to continue . . .

    点赞 打赏 评论

相关推荐 更多相似问题