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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

pat 乙级 1005 继续(3n+1)猜想(C++)

發(fā)布時間:2023/12/2 c/c++ 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 pat 乙级 1005 继续(3n+1)猜想(C++) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題目

卡拉茲(Callatz)猜想已經(jīng)在1001中給出了描述。在這個題目里,情況稍微有些復(fù)雜。

當(dāng)我們驗證卡拉茲猜想的時候,為了避免重復(fù)計算,可以記錄下遞推過程中遇到的每一個數(shù)。例如對 n=3 進(jìn)行驗證的時候,我們需要計算 3、5、8、4、2、1,則當(dāng)我們對 n=5、8、4、2 進(jìn)行驗證的時候,就可以直接判定卡拉茲猜想的真?zhèn)?#xff0c;而不需要重復(fù)計算,因為這 4 個數(shù)已經(jīng)在驗證3的時候遇到過了,我們稱 5、8、4、2 是被 3“覆蓋”的數(shù)。我們稱一個數(shù)列中的某個數(shù) n 為“關(guān)鍵數(shù)”,如果 n 不能被數(shù)列中的其他數(shù)字所覆蓋。

現(xiàn)在給定一系列待驗證的數(shù)字,我們只需要驗證其中的幾個關(guān)鍵數(shù),就可以不必再重復(fù)驗證余下的數(shù)字。你的任務(wù)就是找出這些關(guān)鍵數(shù)字,并按從大到小的順序輸出它們。

輸入格式:

每個測試輸入包含 1 個測試用例,第 1 行給出一個正整數(shù) K (<100),第 2 行給出 K 個互不相同的待驗證的正整數(shù) n (1<n≤100)的值,數(shù)字間用空格隔開。

輸出格式:

每個測試用例的輸出占一行,按從大到小的順序輸出關(guān)鍵數(shù)字。數(shù)字間用 1 個空格隔開,但一行中最后一個數(shù)字后沒有空格。

輸入樣例:

6
3 5 6 7 8 11

輸出樣例:

7 6

分析

  • 按照卡拉茲猜想的步驟,將一個正整數(shù)n(n>1)化到1的過程中,會產(chǎn)生若干個數(shù)。
  • 按照關(guān)鍵數(shù)的定義,可以為每個值指定一個"狀態(tài)",狀態(tài)為true則為關(guān)鍵數(shù),否則不是。然后選擇結(jié)構(gòu)體數(shù)組來存儲每個數(shù)的值(value)和它的初始狀態(tài)(true)。
  • 將每個數(shù)進(jìn)行卡拉茲猜想,將這個過程中產(chǎn)生的數(shù)和結(jié)構(gòu)體數(shù)組其余成員的值進(jìn)行比較,若相等,則將該成員status置為false,進(jìn)行下一輪循環(huán)。
  • 將status為false的結(jié)構(gòu)體成員value置0,進(jìn)行排序,然后按照題給格式輸出即可。

AC代碼

#include<iostream> #include<algorithm> using namespace std; struct node {int value;bool status; }; bool comp(node x,node y) {return x.value>y.value; } int main() {int i,j,K;cin>>K;node a[K];for(i=0;i<K;i++){cin>>a[i].value;a[i].status=true;}for(i=0;i<K;i++){int value=a[i].value;for(j=0;j<K;j++){if(a[j].status==true){if(j!=i){while(1){if(value%2==0)//偶數(shù){value=value/2;if(value==a[j].value){a[j].status=false;value=a[i].value;break;}if(value==1)//該數(shù)卡拉茲猜想產(chǎn)生的所有數(shù)都與當(dāng)前結(jié)構(gòu)體成員value不相等{value=a[i].value;break;}}else//奇數(shù){value=(value*3+1)/2;if(value==a[j].value){a[j].status=false;value=a[i].value;break;}}}}}}}for(i=0;i<K;i++){if(a[i].status==false){a[i].value=0;}}sort(a,a+K,comp);for(i=0;i<K;i++){if(a[i].status==true){if(i==0)cout<<a[i].value;elsecout<<" "<<a[i].value;}}return 0; }

調(diào)試好幾次才通過,一直卡在格式不對,后面先是想到另外拿一個數(shù)組來存儲循環(huán)好的數(shù)組,但在排序的時候仍然不好弄,再想到置0。突然想到,還不如直接對原數(shù)組動手。
如果對你有幫助,請給我一個小小的贊叭!
如果有任何問題或者建議,評論區(qū)燥起來!

更多題解
pat 乙級 題解匯總(持續(xù)更新)(C++)

總結(jié)

以上是生活随笔為你收集整理的pat 乙级 1005 继续(3n+1)猜想(C++)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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