C語言代碼實現(xiàn):6174數(shù)學(xué)黑洞(卡普雷卡爾常數(shù))
1:6174數(shù)學(xué)黑洞現(xiàn)象
2:現(xiàn)象復(fù)現(xiàn)
請輸入一個互不相同的四位數(shù):3758
輸入的四位數(shù)是:3758
第1次:8753 - 3578 = 5175
第2次:7551 - 1557 = 5994
第3次:9954 - 4599 = 5355
第4次:5553 - 3555 = 1998
第5次:9981 - 1899 = 8082
第6次:8820 - 288 = 8532
第7次:8532 - 2358 = 6174
請輸入一個互不相同的四位數(shù):2517
輸入的四位數(shù)是:2517
第1次:7521 - 1257 = 6264
第2次:6642 - 2466 = 4176
第3次:7641 - 1467 = 6174
請輸入一個互不相同的四位數(shù):6915
輸入的四位數(shù)是:6915
第1次:9651 - 1569 = 8082
第2次:8820 - 288 = 8532
第3次:8532 - 2358 = 6174
請輸入一個互不相同的四位數(shù):9073
輸入的四位數(shù)是:9073
第1次:9730 - 379 = 9351
第2次:9531 - 1359 = 8172
第3次:8721 - 1278 = 7443
第4次:7443 - 3447 = 3996
第5次:9963 - 3699 = 6264
第6次:6642 - 2466 = 4176
第7次:7641 - 1467 = 6174
請輸入一個互不相同的四位數(shù):5287
輸入的四位數(shù)是:5287
第1次:8752 - 2578 = 6174
3:C語言代碼的實現(xiàn)
//代碼實現(xiàn) #includeint convert(int number[],int ans); int *sort(int number[],int len); int main(void) { int number[4] = {0}; int *p = NULL; int n = 0; int ans = 0; int count = 0; printf("請輸入一個互不相同的四位數(shù):"); scanf("%d",&n); printf("輸入的四位數(shù)是:%d\n",n); ans = n; while(ans!=6174) { ans = convert(number,ans); printf("第%d次:%d\n",count+1,ans); ++count; } printf("經(jīng)過了%d次最大減最小的動作\n",count); return 0; } int *sort(int number[],int len) //大到小的排序 { int a =0; for(int i=0; i for (int j=i+1;jif(number[i] return number; } int convert(int number[],int ans)//每次變換得到的數(shù)字 { int *p = NULL; int m=0; number[0] = ans/1000; //把這個數(shù)放入數(shù)組 number[1] = ans%1000/100; number[2] = ans%100/10; number[3] = ans%10; p = sort(number,4); m=(*p*1000+*(p+1)*100+*(p+2)*10+*(p+3))- ( *(p+3)*1000+*(p+2)*100+*(p+1)*10+*p);//最大數(shù)字減去最小數(shù)字 return m; }
【1】C語言源代碼展示:常用轉(zhuǎn)換函數(shù)實現(xiàn)原理
【2】Modbus-RTU-crc16校驗方法C語言實現(xiàn)
【3】C語言編程建議和技巧,同樣適用于單片機(jī)的學(xué)習(xí)
【4】單片機(jī)的Bootloader,可以實現(xiàn)用戶輕松升級程序
【5】怎樣才能學(xué)好單片機(jī)?懂方法、有規(guī)劃,才能快速進(jìn)階
【6】單片機(jī)燒錄用的hex文件,文件格式解析
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!