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

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

PAT BASIC 1005

2019-11-11 05:34:43
字體:
來源:轉載
供稿:網友

思路:

給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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 遂平县| 宜丰县| 将乐县| 淮南市| 万盛区| 洛川县| 武夷山市| 芦溪县| 安化县| 乐清市| 黄山市| 五大连池市| 凤冈县| 城市| 永嘉县| 泰宁县| 太原市| 阿克陶县| 呈贡县| 广丰县| 措美县| 昌江| 东城区| 长垣县| 新化县| 紫云| 龙州县| 桦南县| 丹凤县| 云安县| 布尔津县| 鹿邑县| 长岭县| 公安县| 平和县| 离岛区| 南澳县| 阿克苏市| 大悟县| 吴川市| 江北区|