1019 數字黑洞 20

2021-07-30 22:59:43 字數 2179 閱讀 3607

時間限制

100 ms

記憶體限制

65536 kb

**長度限制

8000 b

判題程式

standard

作者 chen, yue

給定任乙個各位數字不完全相同的4位正整數,如果我們先把4個數字按非遞增排序,再按非遞減排序,然後用第1個數字減第2個數字,將得到乙個新的數字。一直重複這樣做,我們很快會停在有「數字黑洞」之稱的6174,這個神奇的數字也叫kaprekar常數。

例如,我們從6767開始,將得到

7766 - 6677 = 1089

9810 - 0189 = 9621

9621 - 1269 = 8352

8532 - 2358 = 6174

7641 - 1467 = 6174

… …現給定任意4位正整數,請編寫程式演示到達黑洞的過程。

輸入格式:

輸入給出乙個(0, 10000)區間內的正整數n。

輸出格式:

如果n的4位數字全相等,則在一行內輸出「n - n = 0000」;否則將計算的每一步在一行內輸出,直到6174作為差出現,輸出格式見樣例。注意每個數字按4位數格式輸出。

輸入樣例1:

6767

輸出樣例1:

7766 - 6677 = 1089

9810 - 0189 = 9621

9621 - 1269 = 8352

8532 - 2358 = 6174

輸入樣例2:

2222

輸出樣例2:

2222 - 2222 = 0000

//寫了乙個巨特麼無敵螺旋丸sb的方法,然後、、、、超時

#include

#include

#include

#include

using namespace std;

bool c1 =false;

string sort1(string &str)//降序

if (str[i] == str[i + 1] && str[i] == str[i + 2] && str[i] == str[i + 3]) // 判斷是不是4個數都相等

int max = i;

for (int j = i+1; j < str.length(); j++)

}swap(str[max],str[i]);

}return

str;

}string sort2(string &str)//公升序

}swap(str[min], str[i]);

}return

str;

}int main()

int n2 = atoi(sort2(a).c_str());//將字串轉換為數字

int res = n1-n2;

string test = a;

if (res<1000)

cout << setw(4) << setfill('0') << n1 << " - "

<< setw(4) << setfill('0') << n2 << " = "

<< setw(4) << setfill('0') << res << endl;

while (res!=6174)

n1 = atoi(sort1(test).c_str());

n2 = atoi(sort2(test).c_str());

res = n1 - n2;

cout << setw(4) << setfill('0') << n1 << " - "

<< setw(4) << setfill('0') << n2 << " = "

<< setw(4) << setfill('0') << res << endl;//不足4為填充0,標頭檔案為

}return0;}

//解法2:

#include

#include

using namespace std;

int inc, de;

void gao(int x)

int main()

do while (s != 6174);

return

0;

}

1019 數字黑洞 20

pat1019 include include include include using namespace std void vector2i vector v,int sum vector轉整型 v.resize 4,0 若不滿4位,則繼續補0 reverse v.begin v.end 反轉...

1019 數字黑洞 20

時間限制 100 ms 記憶體限制 32000 kb 長度限制 8000 b 判題程式 standard 作者 chen,yue 給定任乙個各位數字不完全相同的4位正整數,如果我們先把4個數字按非遞增排序,再按非遞減排序,然後用第1個數字減第2個數字,將得到乙個新的數字。一直重複這樣做,我們很快會停...

1019 數字黑洞 20

給定任乙個各位數字不完全相同的4位正整數,如果我們先把4個數字按非遞增排序,再按非遞減排序,然後用第1個數字減第2個數字,將得到乙個新的數字。一直重複這樣做,我們很快會停在有 數字黑洞 之稱的6174,這個神奇的數字也叫kaprekar常數。例如,我們從6767開始,將得到 7766 6677 10...