1.局部变量和存放函数调用关系的栈帧(可忽略)一起存放在调用栈里,这个空间是有限的,
因为栈帧的关系如果局部变量过大将会导致栈溢出错误。
全局变量有专门存放的段(data段和bss段)。所以一般比较大的数组都作为全局变量放在main外面。
参考柳神代码和晴神代码
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#include<map>
#include<vector>
#include<queue>
using namespace std;
int base[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
int m[11]={1,0,10,9, 8, 7, 6, 5, 4, 3, 2};//将x替换成10了
string s;
//isTrue包含了所有的主体逻辑
bool isTrue() {//string s放在外面,不需要形参
int sum = 0;
for (int i = 0; i < 17; i++) {
if (s[i] < '0' || s[i] > '9') return false;//超出范围的不是数字
sum += (s[i] - '0') * base[i];//同时计算前17位数字的和
}
int temp = (s[17] == 'X') ? 10 : (s[17] - '0');
return m[sum%11] == temp;
}
int main(){
int n;
scanf("%d",&n);
int flag=0;
while(n--){
cin>>s;
if(!isTrue()){
cout<<s<<endl;//endl有包括换行
flag=-1;//如果存在不合格的就位-1
}
}
if(flag==0){
printf("All passed");
}
return 0;
}
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#include<algorithm>
#include<map>
#include<vector>
#include<queue>
using namespace std;
//局部变量和存放函数调用关系的栈帧(可忽略)一起存放在调用栈里,这个空间是有限的,
//因为栈帧的关系如果局部变量过大将会导致栈溢出错误。
//全局变量有专门存放的段(data段和bss段)。所以一般比较大的数组都作为全局变量放在main外面。
int base[17]={7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2};
int m[11]={1,0,10,9, 8, 7, 6, 5, 4, 3, 2};//将x替换成10了
int main(){
int n;
scanf("%d",&n);
string s;
int flag=0;
while(n--){
cin>>s;
//计算前十七位
int sum=0;
int i;
for(i=0;i<17;i++){
if(s[i]<'0'||s[i]>'9'){
break;
}
sum+=(s[i]-'0')*base[i];
}
if(i<17){//说明有错
cout<<s<<endl;
flag=-1;
}else{//一定要有else
//验证检验码是否正确
int temp=0;
if(s[17]=='X'){//不可直接赋值
temp=10;
}else{
temp=s[17]-'0';
}
if(m[sum%11]!=temp) {
flag=-1;
cout<<s<<endl;
}
}
}
//放在循环外,全部检测过后才可以
if(flag==0){
printf("All passed");
}
return 0;
}