|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本人零基础刚学c不久,如果问题比较蠢,请各位见谅。
关于这题,答案的思路是,先求大于10000小于999*999的数中的回文数,再判断是否是由三位数乘积得到;我个人的思路是用循环的嵌套将所有的三位数乘三位数进入循环去判断是否为回文数,从大数进入循环并且判断,然后输出,得到的应该也是最大的回文数,但是结果莫名其妙,想了半天不知道为啥。
希望各位不吝赐教,如果代码中语法有错误,也希望各位能耐心指出,谢谢大家!
本人的代码如下:
- #include<stdio.h>
- int main ()
- {
- int i,j,k,m,n;
- n=0;
-
-
- for(i=999;i>=100&&i<=999;i--)
- {
- j=999;
- for(j;j>=100&&j<=999;j--)
- {
- k=i*j;
- m=k;
- while(m)
- {
- n=n*10+m%10;
- m=m/10;
- }
- if(k==n)
- {
- goto lable;
- }
- }
- }
- lable:printf("%d * %d = %d\n",i,j,k);
- return 0;
- }
复制代码
- #include <stdio.h>
- int hui(int n)
- {
- int d , k , m ;
- for(m = 0 , k = n ; k ; k /= 10) m = m * 10 + k % 10 ;
- if(m == n) return 1 ;
- else return 0 ;
- }
- int main(void)
- {
- int d , i , j , m ;
- for(m = 0 , i = 100 ; i < 1000 ; i ++) {
- for(j = 100 ; j < 1000 ; j ++) {
- d = i * j ;
- if(hui(d) && d > m) m = d ;
- }
- }
- printf("%d\n" , m) ;
- }
复制代码
编译、运行实况
- D:\00.Excise\C>g++ -o hui hui.c
- D:\00.Excise\C>hui
- 906609
- D:\00.Excise\C>
复制代码
|
|