Zeno's cat 2016-08-22 16:24 采纳率: 0%
浏览 1278

PAT-1019-数字黑洞运行超时

#include <stdio.h>
#include <string.h>
#include <math.h>
    int a[4];//不需用字符数组 
    int M;
    int m1,m2;
int fun1(int num){
    int i,j;
    for(i=0;i<4;i++){
        a[i]=num%10;
        num=num/10;
    }
    int max,temp;
    for(i=0;i<3;i++){
        max=i;
    for(j=i+1;j<4;j++)
        if(a[j]>a[max])
            max=j;
        temp=a[max];
        a[max]=a[j];
        a[j]=temp;
    }//看过其他人的代码,这里排序用的是指针,能AC。可是我不用指针就会超时,是因为这个原因吗?还是因为其他的步骤不对?
    m1=a[0]*1000+a[1]*100+a[2]*10+a[3];
    m2=a[3]*1000+a[2]*100+a[1]*10+a[0];
    M=m1-m2;
    return M;
}
int main(){
    scanf("%d",&M);//升序和降序相反,只需一函数
    //由循环得出数组排序,只用输出结果为数字 
    if(M==6174){
        printf("7641 - 1467 = 6174") ;
    }
    while(M!=6174){
        M=fun1(M);
    if(M==0)
    {printf("%d-%d=0000",m1,m2);
            break;
    }       
    else
    {printf("%d%d%d%d-%d%d%d%d=%d%d%d%d",a[0],a[1],a[2],a[3],a[3],a[2],a[1],a[0],M/1000,M/100%10,M/10%10,M%10);
            }
    }

    return 0;
}  
  • 写回答

1条回答 默认 最新

  • threenewbee 2016-08-22 16:31
    关注

    贴出你的代码,需要调试下看看是不是程序中有死循环。

    评论

报告相同问题?

悬赏问题

  • ¥15 使用C#,asp.net读取Excel文件并保存到Oracle数据库
  • ¥15 C# datagridview 单元格显示进度及值
  • ¥15 thinkphp6配合social login单点登录问题
  • ¥15 HFSS 中的 H 场图与 MATLAB 中绘制的 B1 场 部分对应不上
  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 虚心请教几个问题,小生先有礼了
  • ¥30 截图中的mathematics程序转换成matlab