2 baidu 33690068 baidu_33690068 于 2016.03.26 15:38 提问

PAT 数字黑洞问题!!求大神!我要疯了QAQ/(ㄒoㄒ)/~~

#include<stdio.h>
#include<string.h>
void sortdown(int a[]);
void sortup(int b[]); 
int main(void)
{
    char number[4];
    int digit[4];
    int digit2[4];
    int con[4];
    int output=0;
    int i;
    scanf("%s",number);
    for(i=0;i<4;i++)
    {
        digit[i]=number[i]-'0';
    }
    do{

    for(i=0;i<4;i++)
    {
        digit2[i]=digit[i];
    }
    sortdown(digit);
    sortup(digit2);
    for(i=0;i<4;i++)
    {
        con[i]=digit[i]-digit2[i];
    }
    for(i=0;i<4;i++)
    {
        printf("%d",digit[i]);
    }printf(" - ");
    for(i=0;i<4;i++)
    {
        printf("%d",digit2[i]);
    }printf(" = ");
    for(i=0;i<4;i++)
    {
        printf("%d\n",con[i]);
    }
    for(i=0;i<4;i++)
    {
        output=output*10+con[i];
    }

    for(i=0;i<4;i++)
    {
        digit[i]=con[i];
    }
}while(output!=6174);

 } 
void sortdown(int a[])
{
    int i,temp;
    for(i=0;i<3;i++)
    {
        if(a[i+1]<a[i])
        {
        temp=a[i];
        a[i]=a[i+1];
        a[i+1]=temp;
        }
    }
}
void sortup(int b[])
{
    int i,temp;
    for(i=0;i<3;i++)
    {
        if(b[i]>b[i+1])
        {
        temp=b[i+1];
        b[i+1]=b[i];
        b[i]=temp;
        }
    }
}

感觉自己的风格好土,,,执行之后屏幕上的结果一直停不下来。。。/(ㄒoㄒ)/~~

2个回答

qq423399099
qq423399099   Ds   Rxr 2016.03.26 15:50

楼主你的sortdown和sortup函数里for循环是什么情况。。。

baidu_33690068
baidu_33690068 我重新编辑了。。。/(ㄒoㄒ)/~~
2 年多之前 回复
CSDNXIAOD
CSDNXIAOD   2016.03.30 18:00

数字黑洞问题
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
PAT 1019. 数字黑洞
#include                                                              void sortNum(int* a, int* b, int* c, int* d);                                   int main() {                                  
PAT 1019数字黑洞
1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字
Java - PAT - 1019. 数字黑洞 (20)
1019. 数字黑洞 (20) 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字
PAT(乙级)1019. 数字黑洞
给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的6174,这个神奇的数字也叫Kaprekar常数。 例如,我们从6767开始,将得到 7766 - 6677 = 1089 9810 - 0189 = 9621 9621 - 1269 = 8
PAT:数字黑洞
题目链接:https://www.patest.cn/contests/pat-b-practise/1019#include &amp;lt;iostream&amp;gt; #include&amp;lt;algorithm&amp;gt; using namespace std; class Solution{ public: static bool Cmp(char a,char b){ r...
PAT 数字黑洞
题目描述 给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到 一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的6174,这个神奇的数字也叫Kaprekar常数。 例如,我们从6767开始,将得到 7766 - 6677 = 1089 9810 - 0189 = 9621 9621 -
PAT乙级——1009 数字黑洞 (C/C++)
时间限制 1000 ms 内存限制 32768 KB 代码长度限制 100 KB 题目描述 给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到 一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的6174,这个神奇的数字也叫Kaprekar常数。 例如,我们从6767开始,将得到 7766
PAT 乙级 1019. 数字黑洞 (C++版)
给定任一个各位数字不完全相同的4位正整数,如果我们先把4个数字按非递增排序,再按非递减排序,然后用第1个数字减第2个数字,将得到一个新的数字。一直重复这样做,我们很快会停在有“数字黑洞”之称的6174,这个神奇的数字也叫Kaprekar常数。例如,我们从6767开始,将得到7766 - 6677 = 1089 9810 - 0189 = 9621 9621 - 1269 = 8352 8532
PAT Basic 1019. 数字黑洞 (20)
http://pat.zju.edu.cn/contests/pat-b-practise/1019
PAT 7-44 C语言练习题 黑洞数
7-44 黑洞数(20 分)黑洞数也称为陷阱数,又称“Kaprekar问题”,是一类具有奇特转换特性的数。任何一个各位数字不全相同的三位数,经有限次“重排求差”操作,总会得到495。最后所得的495即为三位黑洞数。所谓“重排求差”操作即组成该数的数字重排后的最大数减去重排后的最小数。(6174为四位黑洞数。)例如,对三位数207:第1次重排求差得:720 - 27 = 693;第2次重排求差得:9...