国产探花免费观看_亚洲丰满少妇自慰呻吟_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;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 响水县| 中西区| 淄博市| 迁安市| 嘉兴市| 成武县| 务川| 土默特左旗| 丹江口市| 灌南县| 汝州市| 大邑县| 中山市| 泰顺县| 依兰县| 柞水县| 静安区| 青田县| 顺昌县| 藁城市| 永康市| 砚山县| 贡山| 如东县| 卢龙县| 西宁市| 宽城| 荆州市| 锡林郭勒盟| 灌南县| 松江区| 姜堰市| 洛扎县| 韶关市| 英吉沙县| 顺义区| 乐亭县| 托里县| 璧山县| 崇左市| 安达市|