鱼C论坛

 找回密码
 立即注册
查看: 3509|回复: 4

[已解决]大佬们看看我这个代码可以怎样改进吗

[复制链接]
发表于 2022-12-23 17:07:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
这是一个将非质数拆除几个质数相乘的程序,我的代码基本思路是先将这个非质数拆成一个质数乘上另一个数,
如果另一个数是非质数就重复刚刚的操作,直到所有数都是质数,所以代码里面有很多goto语句,希望大佬们能改进改进,谢谢!
  1. #include<stdio.h>
  2. int main()
  3. {
  4.         long long int a,b,c,d,i,e,f;
  5.         e=0;
  6.         f=0;
  7.         a=1;
  8.         b=2;
  9.         c=600851475143;
  10.         start:
  11.         for(i=b;i<c;i++)
  12.         {
  13.                 if(c%i==0)
  14.                 {
  15.                         a=c/i;
  16.                         if(i==2)
  17.                         {
  18.                                 printf("2 ");                  
  19.                                 goto start1;
  20.                         }
  21.                         else
  22.                         {
  23.                                 for(d=2;d<i;d++)
  24.                                 {
  25.                                         if(i%d==0)
  26.                                         {
  27.                                                 b=i;
  28.                                                 goto start;
  29.                                                 e=1;
  30.                                         }
  31.                                 }
  32.                                 if(e==0)
  33.                                 {
  34.                                         printf("%lld ",i);
  35.                                         goto start1;
  36.                                 }
  37.                         }               
  38.                 }
  39.         }
  40.         start1:
  41.         for(d=2;d<a;d++)
  42.         {
  43.                 if(a%d==0)
  44.                 {
  45.                         c=a;
  46.                         goto start;
  47.                         f=1;
  48.                 }       
  49.         }
  50.         if(f==0)
  51.         {
  52.                 printf("%lld ",a);
  53.         }
  54.         return 0;
  55.        
  56. }
复制代码
最佳答案
2022-12-23 17:45:51
  1. #include <stdio.h>

  2. int main(void) {
  3.     long long int a, b, c, d, i, e, f;
  4.     e = 0;
  5.     f = 0;
  6.     a = 1;
  7.     b = 2;
  8.     c = 600851475143;
  9. start:
  10.     for(i = b; i < c; i++) {
  11.         if(c % i != 0) continue;
  12.         a = c / i;
  13.         if(i == 2) {
  14.             printf("2 ");
  15.             break;
  16.         }
  17.         for(d = 2; d < i; d++) {
  18.             if(i % d != 0) continue;
  19.             b = i;
  20.             goto start;
  21.             //e = 1;    // ???
  22.         }
  23.         if(e != 0) continue;
  24.         printf("%lld ", i);
  25.         break;
  26.     }
  27.     for(d = 2; d < a; d++) {
  28.         if(a % d != 0) continue;
  29.         c = a;
  30.         goto start;
  31.         //f = 1;    // ???
  32.     }
  33.     if(f == 0) printf("%lld ", a);
  34.     return 0;
  35. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-12-23 17:45:51 | 显示全部楼层    本楼为最佳答案   
  1. #include <stdio.h>

  2. int main(void) {
  3.     long long int a, b, c, d, i, e, f;
  4.     e = 0;
  5.     f = 0;
  6.     a = 1;
  7.     b = 2;
  8.     c = 600851475143;
  9. start:
  10.     for(i = b; i < c; i++) {
  11.         if(c % i != 0) continue;
  12.         a = c / i;
  13.         if(i == 2) {
  14.             printf("2 ");
  15.             break;
  16.         }
  17.         for(d = 2; d < i; d++) {
  18.             if(i % d != 0) continue;
  19.             b = i;
  20.             goto start;
  21.             //e = 1;    // ???
  22.         }
  23.         if(e != 0) continue;
  24.         printf("%lld ", i);
  25.         break;
  26.     }
  27.     for(d = 2; d < a; d++) {
  28.         if(a % d != 0) continue;
  29.         c = a;
  30.         goto start;
  31.         //f = 1;    // ???
  32.     }
  33.     if(f == 0) printf("%lld ", a);
  34.     return 0;
  35. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-23 17:47:13 | 显示全部楼层
你的代码中,第29行、47行
在做什么?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-23 18:07:11 | 显示全部楼层
人造人 发表于 2022-12-23 17:47
你的代码中,第29行、47行
在做什么?

是用来判断这个数是不是质数的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-23 18:08:37 | 显示全部楼层
人造人 发表于 2022-12-23 17:47
你的代码中,第29行、47行
在做什么?

哦哦哦,多余了,谢谢大佬指教
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-22 17:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表