武汉科技大学ACM :1005: 零起点学算法101——手机短号

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

HINT

如果用字符串,建议用scanf("%s")读入。

 

我的代码:

 1  #include <iostream>  
 2     using namespace std;  
 3     int main()  
 4     {  
 5         int N;  
 6         cin>>N;  
 7         while(N--){  
 8             char a[11];  
 9             cin>>a;  
10             cout<<'6';  
11             for(int i=6;i<11;i++)  
12                 cout<<a[i];  
13             cout<<endl;  
14         }  
15         return 0;  
16     }  

其他代码:

 1 #include<stdio.h>
 2 #include<string.h>
 3 int main()
 4 {
 5     int n,i=0;
 6     char phone[12];
 7     scanf("%d",&n);
 8     for(i=0;i<n;i++){
 9         scanf("%s",phone);
10         phone[5]='6';
11         for(int j=5;j<11;j++)
12             putchar(phone[j]);
13         printf("\n");
14     }
15     return 0;
16 }
 1 #include <iostream>
 2 
 3 using namespace std;
 4 
 5 int main()
 6 {
 7    int N;
 8    cin>>N;
 9    if(N<=0 || N>200)
10     return 0;
11     char (*a)[11]=new char[N][11];
12      char (*r)[7]=new char[N][7];
13    for(int i=0;i<N;++i)
14    {
15        cin>>a[i];
16        for(int j=6;j<11;++j)
17        {
18            r[i][0] = '6';
19            r[i][j-5] = a[i][j];
20            r[i][6] = '\0';
21        }
22 
23    }
24    for(int i=0;i<N;++i)
25    {
26        cout<<r[i]<<endl;
27    }
28     return 0;
29 }

 

posted @ 2014-12-05 20:04  liuwt365  阅读(611)  评论(0编辑  收藏  举报