日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

15行代码AC——1019 数字黑洞 (20分) 甲级1069. The Black Hole of Numbers (20)(解题报告)

發(fā)布時間:2024/2/28 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 15行代码AC——1019 数字黑洞 (20分) 甲级1069. The Black Hole of Numbers (20)(解题报告) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

立志用更少的代碼做更高效的表達


PAT甲級最優(yōu)題解——>傳送門

Pat乙級最優(yōu)化代碼+題解+分析匯總——>傳送門


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

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

7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174
7641 - 1467 = 6174
… …
現(xiàn)給定任意 4 位正整數(shù),請編寫程序演示到達黑洞的過程。

輸入格式:
輸入給出一個 (0,10?4) 區(qū)間內(nèi)的正整數(shù) N。

輸出格式:
如果 N 的 4 位數(shù)字全相等,則在一行內(nèi)輸出 N - N = 0000;否則將計算的每一步在一行內(nèi)輸出,直到 6174 作為差出現(xiàn),輸出格式見樣例。注意每個數(shù)字按 4 位數(shù)格式輸出。

輸入樣例 1:
6767
輸出樣例 1:
7766 - 6677 = 1089
9810 - 0189 = 9621
9621 - 1269 = 8352
8532 - 2358 = 6174

輸入樣例 2:
2222
輸出樣例 2:
2222 - 2222 = 0000


思路分析:

一刷(中規(guī)中矩的做法):寫了一個排序函數(shù),一個翻轉(zhuǎn)函數(shù), 用while循環(huán)遍歷, 由于輸入如2222或6174這樣的數(shù)需循環(huán)一次再結(jié)束, 因此需要做一個特判。 代碼量大概是40行左右。

二刷:參考了網(wǎng)上大佬的思路, 借助stoll()、to_string()、sort()等函數(shù)完成快速排序及反轉(zhuǎn), 采用do while循環(huán), 這樣就可以在任何情況下都優(yōu)先輸出一次再判斷(巧妙!)。 最后只用了15行代碼就AC了。

雖然代碼二代碼量更少,但是效率并不太高, 因為涉及到了整型與字符型的來回切換。 因此將兩個代碼都放上去, 供大家參考。


關(guān)于stoll()函數(shù)的用法,見這篇博客——>傳送門


思路一

#include<bits/stdc++.h> using namespace std;int Reserve(int r) { int num = 0;int T= 3;while(r) {num += r%10*pow(10, T--);r /= 10;}return num; }int Sort(int r) {int T = 0, a[4] = {0};while(r) {a[T++] = r%10;r /= 10;}sort(a, a+4);int num = 0;for(int i = 0; i < 4; i++) num+= a[i]*pow(10,4-i-1);return num; }int main() {int b1; cin>>b1;b1 = Sort(b1);int b2 = Reserve(b1); if(b1 == b2 || b1 == 6174) {printf("%04d - %04d = %04d\n", b2, b1, b2-b1);return 0; }while(b1!=6174) {b1 = Sort(b1);int b2 = Reserve(b1); printf("%04d - %04d = %04d\n", b2, b1, b2-b1);b1 = b2-b1;} return 0; }

思路二

#include<bits/stdc++.h> using namespace std; int main() {int n; cin>>n; // cout << setfill('0'); //全篇填充0 do{string s = to_string(n); while(s.size() < 4) s += '0';sort(s.begin(), s.end());int a = stoll(s);sort(s.begin(), s.end(), greater<char>());int b = stoll(s);n = b-a;printf("%04d - %04d = %04d\n", b, a, n);} while(n != 0 && n != 6174); return 0; }

總結(jié)

以上是生活随笔為你收集整理的15行代码AC——1019 数字黑洞 (20分) 甲级1069. The Black Hole of Numbers (20)(解题报告)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 天天摸天天碰天天爽天天弄 | 人人澡人人射 | 国产婷婷色一区二区 | 最近中文字幕免费视频 | 伊人超碰 | 色97色| 色天天av | 日韩天堂在线视频 | 久久露脸国语精品国产91 | 九九热在线精品视频 | 免费日韩一区二区 | 又爽又黄又无遮挡 | 国产www在线 | 一区二区高潮 | 国产原创视频在线 | 免费v片在线观看 | 国产偷人 | 99色视频| 美女被娇喘视频 | 福利视频h | 亚洲男女av | 国产欧美日 | 操亚洲女人 | 青青精品 | 免费一级全黄少妇性色生活片 | 精品黄色片 | 黄色录像毛片 | 精品久久久久久久久久久久久 | 亚洲GV成人无码久久精品 | 91成人国产综合久久精品 | 一区二区三区网 | 大地资源中文在线观看免费版 | 色先锋资源网 | 欧美寡妇性猛交ⅹxxx | 粉嫩av蜜桃av蜜臀av | 日本a级片网站 | 黄色aa网站 | 亚洲男人天堂2017 | 国内精久久久久久久久久人 | 嫩草国产精品 | 黄站在线观看 | 日本一区二区三区视频在线播放 | 日韩欧美成人免费视频 | 波多野结av衣东京热无码专区 | 国产成人三级在线观看视频 | 国产第一区第二区 | 亚洲不卡视频在线 | 男人的天堂日韩 | 欧美精品一二三区 | 欧美日韩在线一区二区三区 | 国产一级久久久久毛片精品 | 国产综合av| 97视频| 操极品女神| 日韩一道本| 男朋友是消防员第一季 | 免费看的黄网站 | 九九热精品视频在线播放 | 蜜桃色999 | 黄色片在线播放 | 日本在线二区 | 亚洲91久久 | 一区二区导航 | 亚洲天堂精品一区 | 亚洲人视频 | 永久免费观看av | 欧美一级特黄aaaaaa | 婷婷深爱激情 | 就去吻亚洲 | 日本大尺度吃奶做爰久久久绯色 | 亚洲一区二区国产精品 | 黄色片在哪看 | 香蕉视频成人在线 | 美女高潮视频在线观看 | 小泽玛利亚一区二区三区在线观看 | 亚洲最新在线观看 | 日韩精品成人 | 欧亚成人av | 99色综合网 | av在线资源播放 | 国产激情视频在线播放 | 日日摸日日添日日碰9学生露脸 | 中文字幕在线免费 | 久草免费在线观看 | 国产成人无码专区 | 91免费版黄色 | 日韩午夜一区 | 99r在线视频 | 久久91亚洲精品中文字幕奶水 | 无码人妻少妇伦在线电影 | 撕开少妇裙子猛然进入 | 在线观看中出 | 精品婷婷色一区二区三区蜜桃 | 免费视频二区 | 97视频免费看 | 九九热视频精品在线观看 | 国产真实乱 | www.亚色| 97人人超|