7-3 手机号码
我国使用的手机号码为11位,其中各段有不同的编码方向:前3位是网络识别号;第4-7位为地区编码;第8-11位表示用户号码。
本题要求你实现一个程序,自动统计指定地区编码的手机号码的个数。
输入格式:
输入第一行为待查询的地区编码,随后每行都是11位数字组成的手机号码,当读到某一行只有一个英文句点 . 时,输入结束。
输出格式:
首先在第一行中输出手机号码的总个数。然后统计指定地区编码的手机号码有多少个。第二行首先输出第一次出现该地区编码的手机号码是第几个(从 1 开始计数,没有输出0),然后输出该地区编码手机号码的总个数(没有输出0),其间以一个空格分隔。题目保证输出的所有数字不超过10
9
。
输入样例:
0549
13563910168
13505490199
18853905089
13705390115
.
输出样例:
.4
2 1
代码:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
char search[5];//表示需要查找的地区编号
char tel[12];//输入的手机号
int i = 0;//循环变量
int first_appear = 0;//记住第一个出现的手机号的位次
int count = 0;//用来记录符合要求的手机号的个数
int count1 = 0;//输入多少个手机号
//输入
scanf("%s", &search);//查找的地区号码
scanf("%s", &tel);
if (tel[0] == '0') return 0;
while (1)
{
// printf("%d\n", count1);
count1++;
if (search[0] == tel[3] && search[1] == tel[4] && search[2] == tel[5] && search[3] == tel[6])//查看是否符合
{
count++;
if (count == 1)//记住第一次出现的手机位次
{
first_appear = count1;
}
}
scanf("%s", &tel);//实现一个数组重复输入
if (tel[0] == '.')//循环结束条件
break;
}
//printf("%d\n", i);
printf("%d\n", count1);
printf("%d %d", first_appear, count);
//scanf("%d");
return 0;
}
}