LuoguP7911 [CSP-J 2021] 网络连接 题解
Content
题目过于难解释,请前往题面查看。以下直接给出本题做法。
Solution
入门组 T3 在我印象中向来都不是很容易能做出来的题目,但是今年这个 T3 不得不说还是挺好做的。
我们先不妨令它给出的地址串是合法的,也就是测试点 \(1\sim 11\) 的特殊性质,我们直接用个 map 来存储每个地址串是否已有服务器建立连接,即可解决判断地址串是否已经在前面有服务机建立连接的这个问题,同时对于客户机,这也同样可以判断是否有建立连接的服务机供其连接。
这样,判断给出的地址串是否合法就变成了我们接下来要重点解决的问题。
我们回到题面看看不合法的字符串可能是什么样的:
不是形如
a.b.c.d:e格式的字符串,例如含有多于 \(3\) 个字符.或多于 \(1\) 个字符:等情况。
整数 \(a,b,c,d,e\) 中某一个或多个超出上述范围(即 \(0\leqslant a,b,c,d\leqslant 255\),\(0\leqslant e\leqslant 65535\));
整数 \(a,b,c,d,e\) 中某一个或多个含有多余的前导 \(0\)。
我们根据每个特点将其转化成代码语言。
首先对于不是形如 a.b.c.d;e 格式的地址串,我们直接扫一遍判断其是否恰好有 \(3\) 个 . 和 \(1\) 个 . 即可。同时,我们将第一个 . 前面的部分、第一个 . 和第二个 . 之间的部分、第二个 . 和第三个 . 之间的部分、第三个 . 和 : 之间的部分、: 后面的部分分别提取出来,将字符串的这五个部分分别记作 \(s_1,s_2,s_3,s_4,s_5\)。
之后,对于每个 \(s_i\),我们首先看 \(s_i\) 的首字符是否是 0,然后再去将其转化成数字。在转换的过程中我们需要判断数字是否超出了范围,一旦超出了范围就直接判定其不合法即可。注意,这里之所以在转换的过程中就判断其是否超出范围是因为,如果直接全部转换完再判断,容易超出数据类型范围从而使最终的转换结果不准确。当然地址串的长度不超过 \(\sout{25}\),所以直接用 __int128 是可以保证不爆炸的,但是这里显然不必要用这么大的数据类型去判断一个很小的数字,用上述方法即可仅使用普通的 int 解决是否超出范围的问题而不超出其本身数据类型范围。
这样,判断一个地址串是否合法的过程就全部讲完了。接下来把上面这些部分用代码实现即可。
Code
namespace Solution {
const int N = 1007;
int n;
struct node {string op, ip;}a[N];
map<string, int> id;
ib chk(string s) {
int num = 0, fl = 0, sze = s.size(), p[27] = {0};
string nums[7] = {""};
s = " " + s;
F(int, i, 1, sze) {
if(s[i] == '.') {
p[++num] = i;
if(num > 3) return 0;
} else if(s[i] == ':') {
if(!fl) fl = i;
else return 0;
}
}
if(num < 3 || !fl) return 0;
p[++num] = fl, p[++num] = sze;
F(int, i, 1, num) {
F(int, j, p[i - 1] + 1, p[i] - (i != num)) nums[i] += s[j];
if((nums[i].size() != 1 && nums[i][0] == '0') || nums[i] == "") return 0;
ll x = 0;
F(int, j, 0, (int)nums[i].size() - 1) {
x = x * 10 + nums[i][j] - '0';
if(x > (i == num ? 65535 : 255)) return 0;
}
}
return 1;
}
iv Main() {
read(n);
F(int, i, 1, n) {
cin >> a[i].op >> a[i].ip;
if(a[i].op == "Server") {
if(!chk(a[i].ip)) puts("ERR");
else if(id[a[i].ip]) puts("FAIL");
else puts("OK"), id[a[i].ip] = i;
} else {
if(!chk(a[i].ip)) puts("ERR");
else if(!id[a[i].ip]) puts("FAIL");
else println(id[a[i].ip]);
}
}
return;
}
}
LuoguP7911 [CSP-J 2021] 网络连接 题解的更多相关文章
- CCF CSP 201403-4 无线网络
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201403-4 无线网络 问题描述 目前在一个很大的平面房间里有 n 个无线路由器,每个无线路 ...
- MMORPG大型游戏设计与开发(服务器 游戏场景 掉落与网络连接)
时间一点点的消逝,伴着自己空闲日子将要结束的时候我尽量的学习和分享场景和AI的知识给朋友们,不过很遗憾的是这些文章还有不足的地方,就是有的难点没有完全的分析到.掉落在游戏中必不可少的,同时网络连接也是 ...
- openstack(liberty): 简单网络连接图
openstack起初的网络部分是和计算核心nova合在一起的,后来被拆分出来,独立成为一个模块, 现在名为Neutron. 本博文是学习记录,记录的是基于GRE tunnel技术的neutron和计 ...
- linux虚拟机网络连接模式 bridged, host-only, NAT
最近安装了fedora9.0,却一直不能连接到外网,我用的是3G无线网卡上网的,起初以为是linux不支持3G无线方式的,可后来装了虚拟机ubuntu却可以上网,在后来用有ADSL网络连接的电脑安装f ...
- Docker容器的网络连接
Docker容器的网络连接 Docker容器的网络连接 我们用ifconfig命令来查看网络设备 我们可以看到上面有个叫docker0的网络设备,docker守护进程就是通过docker0为docke ...
- CCF CSP 201709-4 通信网络
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201709-4 通信网络 问题描述 某国的军队由N个部门组成,为了提高安全性,部门之间建立了M ...
- 2021.07.17 题解 CF1385E Directing Edges(拓扑排序)
2021.07.17 题解 CF1385E Directing Edges(拓扑排序) CF1385E Directing Edges - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) ...
- CSP J/S 初赛总结
CSP J/S 初赛总结 2021/9/19 19:29 用官方答案估计 J 涂卡的时候唯一的一支 2B 铅笔坏了,只能用笔芯一个个涂 选择 \(-6\ pts\) 判断 \(-3\ pts\) 回答 ...
- VMware的三种网络连接方式区别
关于VMware的三种网络连接方式,NAT,Bridged,Host-Only ,在刚接触的时候通常会遇到主机Ping不通虚拟机而虚拟机能Ping得通主机:主机与虚拟机互不相通等等网络问题.本文就这三 ...
随机推荐
- 深入理解Redis 数据结构—简单动态字符串sds
Redis是用ANSI C语言编写的,它是一个高性能的key-value数据库,它可以作用在数据库.缓存和消息中间件.其中 Redis 键值对中的键都是 string 类型,而键值对中的值也是有 st ...
- ES2020新特性链操作符 '?.'和'??'
ES2020新特性,js中的可选链操作符?. 概述 回想一下,我们是如何访问可能含有空值(null或undefined)属性的嵌套对象,比如访问web api 返回结果的user详情,可以使用嵌套的三 ...
- 洛谷 P5406 - [THUPC2019]找树(FWT+矩阵树定理)
题面传送门 首先看到这道题你必须要有一个很清楚的认识:这题新定义的 \(\oplus\) 符号非常奇怪,也没有什么性质而言,因此无法通过解决最优化问题的思路来解决这个问题,只好按照计数题的思路来解决, ...
- RNA_seq 热图绘制
若已经拿到表达矩阵exprSet 若差异较大,进行log缩小不同样本的差距 1.热图全体 1 ##加载包 2 library(pheatmap) 3 4 ##缩小表达量差距 5 exprSet < ...
- [源码解析] PyTorch 分布式 Autograd (6) ---- 引擎(下)
[源码解析] PyTtorch 分布式 Autograd (6) ---- 引擎(下) 目录 [源码解析] PyTtorch 分布式 Autograd (6) ---- 引擎(下) 0x00 摘要 0 ...
- 日常Java测试 2021/11/14
课堂测试三 package word_show; import java.io.*;import java.util.*;import java.util.Map.Entry; public clas ...
- 【Maven实战技巧】「插件使用专题」Maven-Archetype插件创建自定义maven项目骨架
技术推荐 自定义Archetype Maven骨架/以当前项目为模板创建maven骨架,可以参考http://maven.apache.org/archetype/maven-archetype-pl ...
- nit是虱子的卵
如题.[牛津] (egg of a) louse or other parasitic insect 虱或其他寄生虫(的卵). 忘了在那个帖子里说nit: 虱子了. 为了凑字数,迄今为止六级/考研单词 ...
- Scala(一)【安装和IDEA中开发】
目录 一.下载 二.windows安装 三.linux环境安装 四.Ida开发Scala 1.在线下载Scala插件 2.离线下载Scala插件 3.验证 五.HelloWorld入门程序 1.新建M ...
- 大数据学习day14-----第三阶段-----scala02------1. 元组 2.类、对象、继承、特质 3.函数(必须掌握)
1. 元组 映射是K/V对偶的集合,对偶是元组的最简单的形式,元组可以装着多个不同类型的值 1.1 特点 元组相当于一个特殊的数组,其长度和内容都可变,并且数组中可以装任何类型的数据,其主要用处就是存 ...