Problem Description
大家都知道,手机号是一个11位长的数字串,同时,作为学生,还可以申请加入校园网,如果加入成功,你将另外拥有一个短号。假设所有的短号都是是 6+手机号的后5位,比如号码为13512345678的手机,对应的短号就是645678。
现在,如果给你一个11位长的手机号码,你能找出对应的短号吗?
Input
输入数据的第一行是一个N(N <= 200),表示有N个数据,接下来的N行每一行为一个11位的手机号码。
Output
输出应包括N行,每行包括一个对应的短号,输出应与输入的顺序一致。
Sample Input
2
13512345678
13787654321
Sample Output
645678
654321
思路:先将6装入新的字符串中,再将手机号后五位装入新字符串,最后输出。
代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int main(int argc, char *argv[]) {
int i,n;
char s[11],a[6];
scanf("%d",&n);
while(n--)
{
scanf("%s",s); //字符串输入不需要加&
a[0]='6'; //‘6’为字符
for(i=1;i<7;i++) //字符串末尾的\0也需要加在新字符串中
a[i]=s[5+i];
printf("%s\n",a);
}
return 0;
}
字符串:
常用字符数组char存放(也可用字符指针),使用%s,必须碰到\0才结束,初始化字符串时自动加\0。
scanf():以空格和回车结束读取,不能输入带空格的字符串。
gets():以回车结束读取,\0结尾。
getchar():得到一个字符。