题目描述
手机号是一个11位长的数字串。同时,大家可以申请加入校园网,如果加入成功,你将另外拥有一个短号。
假设所有的短号都是是 6+手机号的后5位,比如号码为13512345678的手机,对应的短号就是645678。
自定义函数,参数为手机号(字符串),该手机号为合法手机号,则计算该手机号的短号,并用数组传回。返回1;否则返回0。
主函数定义两个串,手机号串和短号串,调用该函数,输出error或得到的短号。
合法手机号判断:11位数字,前三位为:
中国电信:133,153, 180,181,189
中国联通:130,131,132,155,156
中国移动:134,135,136,137,138,182,183,184
(为简化,上述三位数字省去了一些。)
输入
第一行:测试次数
每组测试数据一行,手机号
输出
对每组测试数据,调用函数,根据返回结果,若为1,输出对应短号;若为0,输出error。
输入输出样例
输入样例1 <-复制
3
13512345678
13787654321
11134689044
输出样例1
645678
654321
error
AC代码
#include<stdio.h>
#include<string.h>
// 处理函数,判断手机号是否合法并计算短号
int chuli(char a[])
{
int i, flag1 = 0, flag2 = 0;
// 检查手机号长度是否为11位
if (strlen(a) == 11)
flag2 = 1;
// 合法手机号的前三位数字
int b[][3] = {
{1, 3, 3}, {1, 5, 3}, {1, 8, 0}, {1, 8, 1}, {1, 8, 9}, {1, 3, 0},
{1, 3, 1}, {1, 3, 2}, {1, 5, 5}, {1, 5, 6}, {1, 3, 4}, {1, 3, 5},
{1, 3, 6}, {1, 3, 7}, {1, 3, 8}, {1, 8, 2}, {1, 8, 3}, {1, 8, 4}, {'x'}
};
// 检查手机号的前三位是否为合法数字
for (i = 0; b[i][0] != 'x'; i++)
{
if (a[0] - '0' == b[i][0] && a[1] - '0' == b[i][1] && a[2] - '0' == b[i][2])
flag1 = 1;
}
// 修改短号的前两位为固定数字6
a[1] = '6';
// 重排手机号的后五位数字
for (i = 2; i <= 6; i++)
{
a[i] = a[i + 4];
}
// 如果手机号合法且长度为11位,则返回1;否则返回0
if (flag1 == 1 && flag2 == 1)
return 1;
else
return 0;
}
int main()
{
char a[100];
int t, i, flag;
scanf("%d", &t);
getchar();
while (t--)
{
// 清空数组
memset(a, 0, 100);
// 读取手机号
gets(a);
// 调用处理函数判断手机号并计算短号
flag = chuli(a);
// 根据处理函数的返回值输出结果
if (flag)
{
for (i = 1; i <= 6; i++)
{
printf("%c", a[i]);
if (i == 6)
printf("\n");
}
}
else
{
printf("error\n");
}
}
return 0;
}
根据输入的手机号判断其是否合法,并计算手机号对应的短号。
主要的逻辑是通过处理函数 chuli()
进行判断和计算。
首先检查手机号长度是否为11位,然后判断手机号的前三位数字是否符合合法手机号的规则。
如果是合法手机号,则将短号的前两位数字修改为固定的数字6,并重新排列手机号的后五位数字。最后根据处理函数的返回值输出结果。
(by 归忆)