解题思路:使用正则表达式匹配


注意事项:

匹配 0到99的正则表达式是:[0-9]?\d(问号是匹配前面的字符零或一次)

匹配 100到199的正则表达式是:1\d{2}是以1开头,后边有2个数值的三位数

匹配 200到249的正则表达式是:2[0-4]\d是以2开头,中间是0到4之间的数值,最后是0到9之间的数字的三位数

匹配 250到255的正则表达式是:25[0-5],含义就是以25开头,后边是0到5之间的数值的三位数


所以为了匹配0到255之间的数字,正则表达式为:25[0-5]|2[0-4]\\d|1\\d{2}|[1-9]?\\d

ip是(数值.数值.数值.数值)的格式,就是三个数值加点和一个数值,即是(数值.){3}(数值)

所以正则表达式是(25[0-5]|2[0-4]\\d|1\\d{2}|[1-9]?\\d)\\.){3}(25[0-5]|2[0-4]\\d|1\\d{2}|[1-9]?\\d)




参考代码:

#include<bits/stdc++.h>

using namespace std;

int main(){
	string str;
	regex re("((25[0-5]|2[0-4]\\d|1\\d{2}|[1-9]?\\d)\\.){3}(25[0-5]|2[0-4]\\d|1\\d{2}|[1-9]?\\d)");
	while(cin>>str){
		if(str=="End"){
			break;
		}
		if(regex_match(str,re)){
			cout<<"Y"<<endl;
		}else{
			cout<<"N"<<endl;
		}
	}
	return 0;
}


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 1 条评论

程序媛小秒 2年前 回复TA
这就是正则表达式吗,瞬间变得好简单,比数组和字符串分割简单多了,厉害