【C++ 学习笔记】自定义函数之寻找回文数
题目
寻找并输出11~999之间的数m,它满足m、m2和m3均为回文数。 回文:各位数字左右对称的整数。 列如:11满足上述条件。 11^2=121。 11^3=1331。
一、题目分解
首先判断输入的位数,再判断第一位和最后一位是否相等,第二位和倒数第二位是否相等……。 故定义两个函数,分别为计算输入位数的函数,和判别是否为回文数的函数。
二、代码实现
1.函数定义
代码如下(示例):
#include <iostream> using namespace std; bool reback_numer(int x); int numer_lengh(int x);
2.函数实现
代码如下(示例):
bool reback_numer(int x) {
int lengh = numer_lengh(x);
int *p_ele = new int[lengh];
for (int i = 0; i < lengh; i++)
{
int ele = x % 10;
p_ele[i] = ele;
x /= 10;
}
int mid = lengh / 2 == 1 ? lengh / 2 + 1 : lengh / 2;
bool isres = true;
for (int i = 0; i < mid; i++)
if (p_ele[i]!= p_ele[lengh-1-i]) isres = false;
return isres;
}
int numer_lengh(int x) {
int lengh =0;
while (x){
x /= 10;
lengh++;
}
return lengh;
}
3.主函数
代码如下(示例):
int main()
{
for (int i = 11; i < 1000; i++)
if (reback_numer(i) && reback_numer(i * i) && reback_numer(i * i * i)) cout << i << endl;
return 0;
}
4.输出结果
注意事项
示范代码中,使用了动态数组,动态数组的初始化需要使用指针接收,给动态数组赋(取)值和数组赋(取)值一致,不可以遍历地址取值!!!
上一篇:
通过多线程提高代码的执行效率例子
下一篇:
炉石传说脚本自学之路
