我的PAT系列文章更新重心已移至Github,歡迎來(lái)看PAT題解的小伙伴請(qǐng)到Github Pages瀏覽最新內(nèi)容。此處文章目前已更新至與Github Pages同步。歡迎star我的repo。
題目
一個(gè)合法的身份證號(hào)碼由17位地區(qū)、日期編號(hào)和順序編號(hào)加1位校驗(yàn)碼組成。校驗(yàn)碼的計(jì)算規(guī)則如下:
首先對(duì)前17位數(shù)字加權(quán)求和,權(quán)重分配為:{7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};然后將計(jì)算的和對(duì)11取模得到值Z
;最后按照以下關(guān)系對(duì)應(yīng)Z
值與校驗(yàn)碼M
的值:
Z:0 1 2 3 4 5 6 7 8 9 10
M:1 0 X 9 8 7 6 5 4 3 2
現(xiàn)在給定一些身份證號(hào)碼,請(qǐng)你驗(yàn)證校驗(yàn)碼的有效性,并輸出有問(wèn)題的號(hào)碼。
輸入格式:
輸入第一行給出正整數(shù) (
)是輸入的身份證號(hào)碼的個(gè)數(shù)。隨后
行,每行給出1個(gè)18位身份證號(hào)碼。
輸出格式:
按照輸入的順序每行輸出1個(gè)有問(wèn)題的身份證號(hào)碼。這里并不檢驗(yàn)前17位是否合理,只檢查前17位是否全為數(shù)字且最后1位校驗(yàn)碼計(jì)算準(zhǔn)確。如果所有號(hào)碼都正常,則輸出All passed
。
輸入樣例1:
4
320124198808240056
12010X198901011234
110108196711301866
37070419881216001X
輸出樣例1:
12010X198901011234
110108196711301866
37070419881216001X
輸入樣例2:
2
320124198808240056
110108196711301862
輸出樣例2:
All passed
鳴謝阜陽(yáng)師范學(xué)院范建中老師補(bǔ)充數(shù)據(jù)
思路
也是比較簡(jiǎn)單的題目,檢驗(yàn)前17個(gè)字符是否全是數(shù)字,和第18個(gè)字符和前17個(gè)字符是否相符。
代碼
最新代碼@github,歡迎交流
#include <stdio.h>
int main()
{
int N;
int weight[] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
char ZtoM[] = {'1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'};
char ID[19];
scanf("%d", &N);
int d, sum, count = 0; /* index, weighted sum and count for legal IDs */
for(int i = 0; i < N; i++)
{
scanf("%s", ID);
for(d = 0, sum = 0; d < 17 && ID[d] >= '0' && ID[d] <= '9'; d++)
sum += (ID[d] - '0') * weight[d];
if(d == 17 && ID[17] == ZtoM[sum % 11]) /* legal ID */
count++;
else /* illegal ID */
puts(ID);
}
if(count == N)
puts("All passed");
return 0;
}