细节题,要注意单独判断只有一个负号,形如“-”的情形。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<vector>
using namespace std;
__int128 l,r;
char ch[200005];
int init(){
cin>>ch+1;
int n=strlen(ch+1);
__int128 nw=0;
bool bo=1;
if(ch[1]=='-'){
if(n==1){
return 1;
}
for(int i=2;i<=n;++i){
if(i==2&&ch[i]=='0'){
return 1;
}
nw*=10;
nw+=ch[i]-'0';
if(-nw<l||-nw>r){
return 2;
}
}
return 0;
}else{
for(int i=1;i<=n;++i){
if(i==1&&n>1&&ch[i]=='0'){
return 1;
}
nw*=10;
nw+=ch[i]-'0';
if(nw<l||nw>r){
return 2;
}
}
return 0;
}
}
int main(){
long long L,R;
int T;
scanf("%lld%lld%d",&L,&R,&T);
l=L,r=R;
while(T--){
printf("%d\n",init());
}
return 0;
}