PAT 乙級題目1001

2021-10-08 02:26:34 字數 873 閱讀 6758

卡拉茲(callatz)猜想: 對任何乙個正整數 n,如果它是偶數,那麼把它砍掉一半;如果它是奇數,那麼把 (3n+1) 砍掉一半。這樣一直反覆砍下去,最後一定在某一步得到 n=1。卡拉茲在 1950 年的世界數學家大會上公布了這個猜想,傳說當時耶魯大學師生齊動員,拼命想證明這個貌似很傻很天真的命題,結果鬧得學生們無心學業,一心只證 (3n+1),以至於有人說這是乙個陰謀,卡拉茲是在蓄意延緩美國數學界教學與科研的進展…… 我們今天的題目不是證明卡拉茲猜想,而是對給定的任一不超過 1000 的正整數 n,簡單地數一下,需要多少步(砍幾下)才能得到 n=1?

在這裡插入**片

#include

intmain

(void);

while

(n >1)

printf

("%d"

,i);

return0;

}

在這裡插入**片if(

scanf

("%d"

,&n));

in function 『main』:

6:5: warning: ignoring return value of 『scanf』, declared with attribute warn_unused_result [-wunused-result]

// scanf("%d",&n);

// ^~~~~~~~~~~~~~

尚未解決問題:

n=

(n%2==0

)?n/2:

(3*n+1)/

2;//為什麼這步還要用n=(n%2==0)?

//直接n%2==0?不可以嗎

PAT乙級試題 1001

對任何乙個自然數n,如果它是偶數,那麼把它砍掉一半 如果它是奇數,那麼把 3n 1 砍掉一半。這樣一直反覆砍下去,最後一定在某一步得到n 1。卡拉茲在1950年的世界數學家大會上公布了這個猜想,傳說當時耶魯大學師生齊動員,拼命想證明這個貌似很傻很天真的命題,結果鬧得學生們無心學業,一心只證 3n 1...

PAT乙級1001題解

1001 害死人不償命的 3n 1 猜想 15 分 卡拉茲 callatz 猜想 對任何乙個正整數 n,如果它是偶數,那麼把它砍掉一半 如果它是奇數,那麼把 3n 1 砍掉一半。這樣一直反覆砍下去,最後一定在某一步得到 n 1。卡拉茲在 1950 年的世界數學家大會上公布了這個猜想,傳說當時耶魯大學...

PAT乙級練習(1001)

1001 害死人不償命的 3n 1 猜想 卡拉茲 callatz 猜想 對任何乙個正整數 n,如果它是偶數,那麼把它砍掉一半 如果它是奇數,那麼把 3n 1 砍掉一半。這樣一直反覆砍下去,最後一定在某一步得到 n 1。卡拉茲在 1950 年的世界數學家大會上公布了這個猜想,傳說當時耶魯大學師生齊動員...