解题思路:
1.先判断输入格式是否为x.x.x.x,若果不是直接判断非法
2.遍历输入的字符串,当遍历到 ' . '时,将前面已经遍历的字符串存入临时字符串,再判断此字符串是否合法,然后清空临时字符串,继续遍历。
注意事项:
为保证遍历正确,需要在输入的字符串后面加一个' . ';
参考代码:
#include <iostream> #include <string> #include <algorithm> #include <string.h> #include <stdlib.h> using namespace std; //判断传进来的字符串是否合法 bool isLetem(string s) { for(int i=0; i<s.length(); ++i) { if(s.at(i)<'0' || s.at(i)>'9')//判断是否为数字 return false; } if(s.at(0)=='0' && s.length()>1) //判断是否为以0开始的数字 return false; int tem = atoi(s.c_str()); if(tem>255) return false; return true; } bool isLegalityIP(string ip) { string sip; string tem; //定义临时字符串 sip = ip; int i = 0; sip += '.';//为保证遍历正确,需要在输入的字符串后面加一个' . ' while(i<sip.length()) { if(sip.at(i)=='.') { if(!isLetem(tem))//调用isLetem(); return false; else { tem.clear();//清空临时字符串 i++; continue; } } tem += sip.at(i++);//将遍历的字符存入临时字符串 } return true; } int main() { string str; while(cin>>str) { if(str.find("End")!=string::npos)//输入End of file结束 break; if(count(str.begin(),str.end(),'.')!=3 || str.find("..")!=string::npos)//判断格输入式是否正确 cout<<'N'<<endl; else if(isLegalityIP(str)) cout<<'Y'<<endl; else cout<<'N'<<endl; } return 0; }
0.0分
20 人评分
Hello, world! (C语言代码)浏览:1196 |
C语言程序设计教程(第三版)课后习题9.4 (Java代码)浏览:1416 |
C语言程序设计教程(第三版)课后习题10.5 (C语言代码)浏览:543 |
字符串问题 (C语言代码)浏览:1501 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:449 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:470 |
IP判断 (C语言代码)浏览:761 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:534 |
C语言程序设计教程(第三版)课后习题7.1 (C语言代码)浏览:610 |
【矩阵】 (C++代码)浏览:936 |