#include <iostream>
#include <cstdio>
#include <string>
using namespace std;
struct node {
int num;//计算机编号
string s;//服务器地址
} Node[1005];
string op, ad; //电脑类型,IP地址
int n, k, sn; //电脑数量,有效的服务器数量,找到的服务器编号
bool check(string &b) {
int ip[30], ipc[30] = {0}; //ip地址段,段长度
char fg[30], qd[30]; //分隔符,前导符
int l = b.size();
if (b[0] < '0' || b[0] > '9' || b[l - 1] < '0' || b[l - 1] > '9') {
return 0;//判断是否是数字开始和结束
//确保是数字开头和结尾
}
int i = 0, j = 0, fgc = 0;
while (i < l) {
qd[j] = b[i]; //首位数字的处理
ip[j] = b[i] - '0';
ipc[j]++;
i++;//进入下一个字符
while (b[i] >= '0' && b[i] <= '9' && i < l) { //还是数字并且未结束
ip[j] = ip[j] * 10 + b[i] - '0';
if (ip[j] > 65535) {
return 0;//避免数字太长,ip[j]存不下
}
ipc[j]++;
i++;
}
j++;
while ((b[i] == '.' || b[i] == ':') && i < l) {
fg[fgc] = b[i];
fgc++;
i++;
}
}
if (j != 5 || fgc != 4) { //判断数字和分隔符是否多了或减少了
return 0;
}
if (fg[0] != '.' || fg[1] != '.' || fg[2] != '.' || fg[3] != ':') {
return 0;
}
if (ip[0] > 255 || ip[1] > 255 || ip[2] > 255 || ip[3] > 255) {
return 0;
}
if (qd[0] == '0' && ipc[0] > 1 || qd[1] == '0' && ipc[1] > 1 || qd[2] == '0' && ipc[2] > 1 || qd[3] == '0' && ipc[3] > 1 || qd[4] == '0' && ipc[4] > 1) {
return 0;
}
return 1;
}
int same(string &b) {
for (int i = 0; i < k; i++) {
if (b == Node[i]. s) {
return Node [i].num;
}
}
return 0;
}
int main() {
// freopen("network.in","r",stdin);
// freopen("network.out","w",stdout);
cin>>n;
for(int i=1;i<=n;i++){
cin>>op>>ad;
if(!check(ad)){
cout<<"ERR"<<endl;
continue;
}
sn=same(ad);
if(op=="Server" && !sn){
cout<<"OK"<<endl;
Node[k].num=i;
Node[k].s=ad;
k++;
}else if(op=="Client" && sn){
cout<<sn<<endl;
}else{
cout<<"FAIL"<<endl;
}
}
fclose(stdin);
fclose(stdout);
return 0;
}
2021复赛网络连接(network)
于 2023-10-04 11:29:48 首次发布