此问题可借助数组来解决。将平方后的(a的)每一位进行分解,按从低位到高位的顺序依次暂存到数组中,再将数组中的元素按照下标从大到小的顺序重新将其组合成一个数众(如n=15,则a=225且k=522),若k等于n×n则可判定n为回文数。算法设计从低位到高位将某一整数拆分。对于一个整数(设变量名为a)无论其位数多少,若欲将最低位拆分,只需对10进行求模运算a%10,拆分次低位首先要想办法将原来的次低位作为最低位来处理,用原数对10求商可得到由除最低位之外的数形成的新数,且新数的最低位是原数的次低位,根据拆分最低位的方法将次低位求出a/10、a%10,对于其他位上的数算法相同。
利用这个方法要解决的一个问题就是,什么情况下才算把所有数都拆分完?当拆分到只剩原数最高位时(即新数为个位数时),再对10求商的话,得到的结果肯定为0,可以通过这个条件判断是否拆分完毕。根据题意,应将每次拆分出来的数据存储到数组中,原数的最低位存到下标为0的位置,次低位存到下标为1的位置……依次类推。
程序段如下:
for (i=0; a!=0; i++){ m[i] = a % 10; a /= 10;}将数组中元素重新组合成一新数。拆分时变量a的最高位仍然存储在数组中下标最大的位置,根据“回文数”定义,新数中数据的顺序与a中数据的顺序相反,所以我们按照下标从大到小的顺序分别取出数组中的元素组成新数k,由几个数字组成一个新数时只需用每一个数字乘以所在位置对应的权值然后相加即可,在编程过程中应该有一个变量t来存储每一位对应的权值,个位权值为1,十位权值为10,百位权值为100……,所以可以利用循环,每循环一次t的值就扩大10倍。对应程序段如下:
for( ; i>0; i--){ k += m[i-l] * t; t *= 10;}
下面是完整的代码:
#include<stdio.h>int main(){ int m[16],n,i,t,count=0; long unsigned a,k; printf("No. number it's square(palindrome)\n"); for( n=1; n<256; n++ ) /*穷举n的取值范围*/ { k=0; t=1; a=n*n; /*计算n的平方*/ for( i=0; a!=0; i++ ) /*从低到高分解数a的每一位存于数组m[1]~m[16]*/ { m[i] = a % 10; a /= 10; } for(; i>0; i--) { k += m[i-1] * t; /*t记录某一位置对应的权值 */ t *= 10; } if(k == n*n) printf("%2d%10d%10d\n",++count,n*n); } return 0;}运行结果:
No. number it's square(palindrome) 1 1 1 2 2 4 3 3 9 4 11 121 5 22 484 6 26 676 7 101 10201 8 111 12321 9 121 1464110 202 4080411 212 44944总结
以上是内存溢出为你收集整理的C语言求回文数(详解版)全部内容,希望文章能够帮你解决C语言求回文数(详解版)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)