|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
我的代码
- #include<stdio.h>
- int main()
- {
- int i,target,daozhishu = 0,num= 998001;
-
- for( ; num > 10000 ; num--)
- {
- target = num;//num自减,对于每一个num,都执行下面的操作!
- while(target)
- {
- daozhishu = daozhishu * 10 + target % 10;//得到倒置数的标准方法
- target = target / 10;
- }//这个循环持续到我们的对象数字变为零,此时daozihshu就是原数字的倒置数
-
- if(daozhishu == num)
- {
- for(i = 100;i < 1000;i++)
- {
- if(!(num%i) && (num/i > 100) && (num/i < 1000))
- {
- goto FINDIT;
- }
- }
- }
- }
- FINDIT : printf("结果是%d == %d * %d\n",num,i,num/i);
- return 0;
- }
复制代码
答案的代码
- #include <stdio.h>
- int main()
- {
- int i, j, target, invert = 0, num = 998001; // 999 * 999
- for ( ; num > 10000; num--)
- {
- // 先求倒置数
- target = num;
- invert = 0;
- while (target)
- {
- invert = invert * 10 + target % 10;
- target = target / 10;
- }
- // 如果跟倒置数一致,说明该数是回文数
- if (invert == num)
- {
- for (i = 100; i < 1000; i++)
- {
- if (!(num % i) && (num / i >= 100) && (num / i < 1000))
- {
- goto FINDIT;
- }
- }
- }
- }
- FINDIT: printf("结果是%d == %d * %d\n", num, i, num / i);
- return 0;
- }
复制代码
为什么抄都抄不对呀呀呀呀
这段代码的目的是寻找最大的回文数,该回文数是三位数的两个乘积。抄袭代码是不正确的行为,应该通过理解代码来找到问题所在。
在原代码中,每次循环都会改变变量 daozhishu 的值,但在代码中并没有将其清零,导致每次循环后 daozhishu 的值一直在增大,最终导致程序无法正确运行。正确的做法是在每次循环开始前将 daozhishu 的值清零。
修改后的代码如下:
- #include <stdio.h>
- int main()
- {
- int i, j, target, invert = 0, num = 998001; // 999 * 999
- for (; num > 10000; num--)
- {
- // 先求倒置数
- target = num;
- invert = 0;
- while (target)
- {
- invert = invert * 10 + target % 10;
- target = target / 10;
- }
- // 如果跟倒置数一致,说明该数是回文数
- if (invert == num)
- {
- for (i = 100; i < 1000; i++)
- {
- if (!(num % i) && (num / i >= 100) && (num / i < 1000))
- {
- goto FINDIT;
- }
- }
- }
- }
- FINDIT:
- printf("结果是%d == %d * %d\n", num, i, num / i);
- return 0;
- }
复制代码
|
|