国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

PAT BASIC 1005

2019-11-11 04:06:25
字體:
來源:轉載
供稿:網友

思路:

給1~100的數做一個state標記數組

state[1]=1;state[i]=0; //i!=1

每個數進來之后都做那個1001操作,遇到

state[i]==1

的情況停止,否則都將state[i]賦值為1; 需要注意的一點就是state數組一定要開的大,雖然說n最大是100,但是我開了1000的數組依然出錯了。

代碼:

#include<iostream>using namespace std;int num[201], state[10001], isNum[201], ans[201];int n;int main(){ int i, j; int sam; cin >> n; for (i = 2; i <= 100; i++) { state[i] = 0; isNum[i] = 0; } state[1] = 1; for (i = 0; i < n; i++) { cin >> num[i]; isNum[num[i]] = 1; } for (i = 0; i < n; i++) { sam = num[i]; if (sam == 1) continue; if (sam % 2 == 1) sam = sam * 3 + 1; sam = sam / 2; while (state[sam] == 0) { state[sam] = 1; if (sam % 2 == 1) sam = sam * 3 + 1; sam = sam / 2; } } ans[0] = 0; for (i = 100; i > 1; i--) { if (isNum[i] && state[i] == 0) { ans[0]++; ans[ans[0]] = i; } } for (i = 1; i < ans[0]; i++) cout << ans[i] << " "; cout << ans[ans[0]]; //while (1) //{ //} return 0;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 廊坊市| 迁西县| 伊宁县| 察雅县| 伊吾县| 永泰县| 鹤岗市| 贡嘎县| 霍城县| SHOW| 孝昌县| 日喀则市| 周口市| 永仁县| 息烽县| 通河县| 讷河市| 彭山县| 平舆县| 清水河县| 青州市| 小金县| 明光市| 常宁市| 平罗县| 天台县| 江口县| 凌云县| 夏河县| 武清区| 乌兰浩特市| 屏东县| 大同县| 徐水县| 育儿| 平南县| 隆尧县| 于都县| 新和县| 岳池县| 金溪县|