https://vjudge.net/contest/447075#problem/A
A题:A+B高精度问题:
#include <iostream>
#include <cstring>
using namespace std;
const int N=1010;
int a[N],b[N],c[N];
int i,sum,jin,lena,lenb,lenm;
string A,B;
int main(){
int t,cnt=1;
cin>>t;
while(t--){
cin>>A>>B;
lena=A.size();
lenb=B.size();
lenm=max(lena,lenb);
memset(a,0,sizeof(a));//必须初始化
memset(b,0,sizeof(b));
memset(c,0,sizeof(c));
for(i=0;i<lena;i++){
a[lena-i-1]=A[i]-'0';
}//倒序
for(i=0;i<lenb;i++){
b[lenb-i-1]=B[i]-'0';
}
for(i=0;i<lenm;i++){
sum=a[i]+b[i]+jin;
c[i]=sum%10;
jin=sum/10;
}
if(jin>0){
c[i]=jin;
i++;
}//进位相加
cout<<"Case "<<cnt<<':'<<endl;
cout<<A<<" + "<<B<<" = ";
for(int j=i-1;j>=0;j--){
cout<<c[j];
}
cout<<endl;
if(t!=0) cout<<endl;//两个case间有空行
cnt++;
}
return 0;
}
K题:考察思维
#include <iostream>
#include <string>
#include <cmath>
using namespace std;
int main(){
int t;
cin>>t;
while(t--){
int a,b,cnt=0,c=10;
cin>>a>>b;
while(b>=c-1){ //当b>=9 ,99 ,999,。。。
cnt++;
c*=10;
}
cout<<a*cnt<<endl;//妙啊
}
return 0;
}
D题:考察思维
难啊
#include <iostream>
#include <string>
#include <cmath>
#include <algorithm>
using namespace std;
const int N=100010;
int h[N];
int main(){
int t;
cin>>t;
while(t--){
int n,s=0,flag=0;
cin>>n;
for(int i=0;i<n;i++){
cin>>h[i];
}
sort(h,h+n);
for(int i=1;i<n;i++){
if((h[i]-h[i-1])%2==0){
flag=1;
}
}
if(flag){
cout<<"yes"<<endl;
}else{
cout<<"no"<<endl;
}
}
return 0;
}
G题 机器人
有些不懂
https://blog.csdn.net/weixin_44824383/article/details/105024183