1002. 写出这个数 (20)
时间限制
400 ms
内存限制
65536 kB
代码长度限制
8000 B
判题程序
Standard
作者
CHEN, Yue
读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100。
输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:1234567890987654321123456789输出样例:
yi san wu
/**
作者:一叶扁舟
时间:15:34 2017/6/29
思路:
*/
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#define SIZE 111
int main3(){
char M[11] = { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' };//校验码
//权重分配
int weight[17] = {7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2};
int sum = 0;
int errNum = 0;
char errorResult[SIZE][20];
int N; //输入的测试数据组数
char temp[20];
scanf("%d", &N);
for (int i = 0; i < N; i++){
sum = 0;
scanf("%s",temp);
int count = strlen(temp);
for (int j = 0; j < count; j++){
int num = temp[j] - '0';//得到该数据值范围为0-9,最后一位可以大于10,校验码大于10即为X
if (num >10 && j != count -1){//说明含有非数字字符,则错误
strcpy(errorResult[errNum], temp);
errNum++;
break;
}
//得到和值
if (j != count - 1){
sum = sum + num * weight[j];
}
else{
//验证最后一个数据对不对
int z = sum % 11;
if (num != (M[z] - '0') ){//身份验证失败
strcpy(errorResult[errNum], temp);
errNum++;
break;
}
}
}
}
//输出结果
if (errNum == 0){//全部验证通过
printf("All passed\n");
}
else{//输出所有错误的省份证
for (int i = 0; i < errNum - 1; i++){
printf("%s\n",errorResult[i]);
}
}
system("pause");
return 0;
}