PTA 1021 個位數統計(C語言)
阿新 • • 發佈:2018-11-12
我對這道題的基本思路是:通過字串輸出這些數,然後進行遍歷,使用新建的陣列對重複出現的數字進行儲存,最後輸出值陣列中值不為零的數。
最關鍵的是:利用下標來儲存重複的數並使下標的值自增。
這個比較繁瑣,還會有更簡練的,望各位大佬指出不足。
程式碼如下:
#include <stdio.h> int main(void) { char num[1024]; int record[10] = {0}; int i = 0; if(scanf("%s", num)); for (i = 0; num[i]; i++) { switch (num[i] - '0') { case 0: record[num[i] - '0']++; break; case 1: record[num[i] - '0']++; break; case 2: record[num[i] - '0']++; break; case 3: record[num[i] - '0']++; break; case 4: record[num[i] - '0']++; break; case 5: record[num[i] - '0']++; break; case 6: record[num[i] - '0']++; break; case 7: record[num[i] - '0']++; break; case 8: record[num[i] - '0']++; break; case 9: record[num[i] - '0']++; break; } } for (i = 0; i<10; i++) { if (record[i] != 0) { printf("%d:%d\n", i,record[i]); } } return 0; }