手机短号
作者: xxx
时间限制: 1s
章节: 字符串
问题描述
大家都知道,手机号是一个11位长的数字串,同时,作为学生,还可以申请加入校园网,如果加入成功,你将另外拥有一个短号。假设所有的短号都是"6"+手机号的后5位,比如号码为13512345678的手机,对应的短号就是645678。
现在,如果给你一个11位长的手机号码,你能找出对应的短号吗?
输入说明
输入数据的第一行是一个N(N <= 1000),表示有N个数据,接下来的N行每一行为一个11位的手机号码。
输出说明
输出应包括N行,每行包括一个对应的短号,输出应与输入的顺序一致。
个人总结 无
代码
cpp
#include <bits/stdc++.h>
using namespace std;
int main(){
int n;
cin>>n;
while(n--){
char arr[11]={0};
cin>>arr;
cout<<"6";
for(int i=6;i<11;i++){
cout<<arr[i];
}
cout<<endl;
}
}
字符串统计
作者: xxx
时间限制: 1s
章节: 字符串
问题描述
对于给定的一个字符串,统计其中小写字母出现的次数。
输入说明
输入数据有多行,第一行是一个整数n,表示测试实例的个数,后面跟着n行,每行包括一个由字母和数字组成的字符串。
输出说明
对于每个测试实例,输出该串中数值的个数,每个输出占一行。
个人总结 无
代码
cpp
#include <bits/stdc++.h>
using namespace std;
int main(){
int n;
cin>>n;
while(n--){
char arr[1000]={0};
cin>>arr;
int count=0;
for(int i=0;i<strlen(arr);i++){
if(arr[i]>='a'&&arr[i]<='z') count++;
}
cout<<count<<endl;
}
}
弟弟的作业
作者: xxx
时间限制: 1s
章节: 字符串
问题描述
你的弟弟刚做完了"100以内数的加减法"这部分的作业,请你帮他检查一下。每道题目(包括弟弟的答案)的格式为a+b=c或者a-b=c,其中a和b是作业中给出的,均为不超过100的非负整数;c是弟弟算出的答案,可能是不超过200的非负整数,也可能是单个字符"?",表示他不会算。
输入说明
输入文件包含不超过100行,以文件结束符结尾。每行包含一道题目,格式保证符合上述规定,且不包含任何空白字符。输入的所有整数均不含前导0。
输出说明
输出仅一行,包含一个非负整数,即弟弟答对的题目数量。
个人总结
1、需要手动结束输入
2、看错题目了,c是非负整数,不过无伤大雅
代码
cpp
#include <bits/stdc++.h>
using namespace std;
int main(){
int count=0;
char arr[20]={0};
while(cin>>arr){
int k=0;
//解析第一个数
int a=0;
while(arr[k]!='+'&&arr[k]!='-'){
a=a*10+(arr[k]-'0');
k++;
}
//符号
char fu=arr[k++];
//解析第二个数
int b=0;
while(arr[k]!='='){
b=b*10+(arr[k]-'0');
k++;
}
//跳过等号
k++;
//解析第三个数
int c=0;
int mark=1;//表示为正数
if(arr[k]=='?') continue;
else{
if(arr[k]=='-'){
mark=0;//表示为负数
k++;
}
else{
while(arr[k]!='\0'){
c=c*10+(arr[k]-'0');
k++;
}
}
}
if(mark==0) c=-c;
if(fu=='+'){
if(a+b==c) count++;
}else{
if(a-b==c) count++;
}
}
cout<<count<<endl;
}