CSP历年复赛题-P7911 [CSP-J 2021] 网络连接

news/2024/9/21 12:36:53

原题链接:https://www.luogu.com.cn/problem/P7911

题意解读:服务器server建立连接,客户端client加入连接,建立和加入连接都要指定一个ip地址,对已经建立过连接的ip地址再次建立连接会失败,加入连接没有限制,根据要求进行输出。

解题思路:

此题有两个关键点:

1、验证IP地址的格式是符合规范的,不合规范要输出ERR

2、建立连接时,用map保存已经建立连接的IP地址,用于判断是否存在,如果不存在则建立连接成功并加IP地址和编号加入map,如果存在则FAIL

3、加入连接时,判断IP是否在map中存在,如果存在则输出IP对应的编号,如果不存在则FAIL

100分代码:

#include <bits/stdc++.h>
using namespace std;int n;
string type, ip;
map<string, int> h;bool check(string ip)
{vector<int> dot; //点号的位置vector<int> mao; //冒号的位置for(int i = 0; i < ip.size(); i++){if(ip[i] == '.') dot.push_back(i);if(ip[i] == ':') mao.push_back(i);}if(dot.size() != 3 || mao.size() != 1) return false;//判断aint a = 0;int l = 0, r = dot[0];if(r - l <= 0 || r - l > 3) return false; //a长度不对if(ip[l] == '0' && r - l > 1) return false; //a有前导0for(int i = l; i < r; i++) {if(ip[i] < '0' || ip[i] > '9') return false; //a有非数字字符a = 10 * a + ip[i] - '0';}if(a < 0 || a > 255) return false; //a范围不对//判断bint b = 0;l = dot[0] + 1, r = dot[1];if(r - l <= 0 || r - l > 3) return false; //b长度不对if(ip[l] == '0' && r - l > 1) return false; //b有前导0for(int i = l; i < r; i++) {if(ip[i] < '0' || ip[i] > '9') return false; //b有非数字字符b = 10 * b + ip[i] - '0';}if(b < 0 || b > 255) return false; //b范围不对//判断cint c = 0;l = dot[1] + 1, r = dot[2];if(r - l <= 0 || r - l > 3) return false; //c长度不对if(ip[l] == '0' && r - l > 1) return false; //c长度为0或者有前导0for(int i = l; i < r; i++) {if(ip[i] < '0' || ip[i] > '9') return false; //c有非数字字符c = 10 * c + ip[i] - '0';}if(c < 0 || c > 255) return false; //c范围不对//判断dint d = 0;l = dot[2] + 1, r = mao[0];if(r - l <= 0 || r - l > 3) return false; //d长度不对if(ip[l] == '0' && r - l > 1) return false; //d有前导0for(int i = l; i < r; i++) {if(ip[i] < '0' || ip[i] > '9') return false; //d有非数字字符d = 10 * d + ip[i] - '0';}if(d < 0 || d > 255) return false; //b范围不对//判断eint e = 0;l = mao[0] + 1, r = ip.size();if(r - l <= 0 || r - l > 5) return false; //e长度不对if(ip[l] == '0' && r - l > 1) return false; //e有前导0for(int i = l; i < r; i++) {if(ip[i] < '0' || ip[i] > '9') return false; //e有非数字字符e = 10 * e + ip[i] - '0';}if(e < 0 || e > 65535) return false; //e范围不对return true;
}int main()
{cin >> n;for(int i = 1; i <= n; i++){cin >> type >> ip;if(!check(ip)) cout << "ERR" << endl;else{if(type == "Server"){if(h[ip]) cout << "FAIL" << endl;else{h[ip] = i;cout << "OK" << endl;} }else if(type == "Client") {if(h[ip]) cout << h[ip] << endl;else cout << "FAIL" << endl;}}}return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hjln.cn/news/46931.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

网络基本认知(1)--网络基础知识

实 验 目 的 和 要 求理解和掌握有关网络的概念、分类、组成等基本知识。 通过使用网络,了解a网络的基本功能。 网络性能对网络使用者来说至关重要,理解影响网络的使用有关因素。 通过对互联网的认知,从某一方面探讨对《互联网+》中的“+”理解,并谈一谈您的想法。 (宋体小…

WPF使用XAML实现报表的一种思路(支持外部加载)

在WPF里做报告这一块以前用过多种实现方式,有用过RDLC、XPS等,看过一些开源的报表控件,跟RDLC的原理都差不多。 最近刚好又要实现报表的功能,就想直接使用XAML实现,直接将界面呈现的内容打印出来。打印WPF元素 在我前面的文章中,介绍过如何使用PrintDialog打印WPF元素, …

Hadoop习题汇总(更新中)

目录选择单选多选判断填空简答 选择 单选 查看HDFS系统版本的Shell命令,以下正确的是()。 hdfs -ver hdfs version (答案) dfsadmin version hadoop -ver 数据存储单位从小到大排列顺序是() TB、PB、EB、ZB、YB (答案) TB、YB、ZB、PB、EB TB、PB、EB、YB、ZB TB、EB、…

如何提取PDF文件的其中几页?

如何提取pdf中的页面?在使用PDF文件时,如果我们只想要PDF中的几页,保存整个PDF是完全没有必要的,那么应该怎么做呢?其实只要提取PDF页面就可以了,那么提取操作具体应该怎么做呢?下面这篇文章肯定可以帮你解决疑惑! 第一个方法在线拆分,不需要下载安装超方便。 smallpd…

S7指令中的PUT/GET或者BSEND/BRCV的选择

1. 背景最近用一个300PLC和1200PLC做S7通信的时候,因为交互的数据量有1024个bytes.这才意识到put get在数据量上的限制。以及大数据传输用到的BSEND/BRCV。2. S7支持的指令在PLC里,能基于S7协议用于数据交换的指令如下(S7 300/400下描述):其中值得注意的有几点:put/get无…

Character Animator 2024 mac/win版:赋予角色生命,动画更传神

Character Animator 2024是一款强大的角色动画制作软件,以其创新的功能和卓越的性能,为动画师、游戏开发者以及设计师们带来了全新的创作体验。 Character Animator 2024 mac/win版获取 这款软件采用了先进的骨骼绑定技术,使得角色动画的制作变得更为轻松和精准。用户可以轻…

新兴互联网银行搭档Apache SeaTunnel构建数据流通管道!

当新兴互联网银行乘着数字化改革的风潮搭档数据集成平台Apache SeaTunnel,成千万上亿的数据就有了快速流通的管道。6月26日14:00,Apache SeaTunnel社区将带上企业最佳实践与观众见面,与大家面对面交流最新的企业实践部署经验。锁定SeaTunnel视频号,马上预约直播! 活动议程…

【ACM独立出版/Fellow大咖云集】 第三届机器人、人工智能与信息工程国际学术会议(RAIIE 2024)

2024年第二届机器人、人工智能与信息工程国际学术会议(RAIIE 2024)将于2024年7月5-7日在新加坡举行。2024年第二届机器人、人工智能与信息工程国际学术会议(RAIIE 2024)将于2024年7月5-7日在新加坡举行。本次会议主要围绕“机器人”、“智能仿生”和“信息科学”的最新研究…