H - 手机短号
大家都知道,手机号是一个11位长的数字串,同时,作为学生,还可以申请加入校园网,如果加入成功,你将另外拥有一个短号。假设所有的短号都是是 6+手机号的后5位,比如号码为13512345678的手机,对应的短号就是645678。
现在,如果给你一个11位长的手机号码,你能找出对应的短号吗?
Input
输入数据的第一行是一个N(N <= 200),表示有N个数据,接下来的N行每一行为一个11位的手机号码。
Output
输出应包括N行,每行包括一个对应的短号,输出应与输入的顺序一致。
Sample Input
2
13512345678
13787654321
Sample Output
645678
654321
思路一
scanf()里的%*d —— “ * ” 符:用以表示该输入项,读入后不赋予相应的变量,即跳过该输入值。
scanf()里的%md ——读取m位数
printf()里的%0md——输出占位符,不足m位左边用0补齐,如%04d,a=1,输出0001
t为int型,读入的时候,如135123400789,t=789,为了输出600789,用6%0md
代码
#include<stdio.h>
int main(){
int n;
scanf("%d",&n);
while(n--){
int t;
scanf("%*6d%5d",&t);
printf("6%05d\n",t);
}
return 0;
}
思路二
【C++】substr()函数
substr()函数定义于头文件
一、参数:(pos, n)
pos - 从此位置开始拷贝
n - 拷贝 n 长度的字符串
二、形式:s.substr(pos, n)
三、解释:返回一个string,包含s中从pos开始的n个字符的拷贝。
代码
#include<iostream>
#include<stdio.h>
#include<string>
using namespace std;
int main(){
int n;
cin>>n;
while(n--){
string a;
cin>>a;
cout<<"6"<<a.substr(6,5)<<endl;
}
return 0;
}
string库也是一个坑啊待填
老师说的对,我们对C标准一无所知