解题思路:
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 人评分
陶陶摘苹果 (C语言代码)浏览:1652 |
汽水瓶 (C语言代码)浏览:764 |
A+B for Input-Output Practice (VII) (C++代码)浏览:643 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:1555 |
校门外的树 (C语言代码)浏览:988 |
WU-格式化数据输出 (C++代码)浏览:1312 |
C语言程序设计教程(第三版)课后习题10.2 (C语言代码)浏览:560 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:1207 |
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:527 |
简单的a+b (C语言代码)浏览:443 |