设为首页 收藏本站
查看: 1139|回复: 0

[经验分享] 华为练习1 IP地址判断有效性

[复制链接]

尚未签到

发表于 2016-6-7 02:55:00 | 显示全部楼层 |阅读模式
bool isIPAddressValid(const char* pszIPAddr)
{
// 请在此处实现
char allChar[15];//声明字符串数组
int charLength=0;//字符串长度
int pointNum=0;//.的数量,使其符合XXX.XXX.XXX.XXX格式
//if(pszIPAddr==NULL)return false;
if(pszIPAddr==0)return false;
while(*pszIPAddr!='\0'){
allChar[charLength++]=*pszIPAddr++;//先将字符串全部保存在allchar数组中,并记录字符串长度
if(charLength>15)return false;//字符串没有终止??
}
for(int i=0;i<charLength;i++){
if(allChar==' '){
return false;//当出现空格时,错误
}else if(allChar=='.'){
if(i==charLength-1||i==0)return false;//当点在最初位置或最后时,出错
else if(allChar[i+1]=='.')return false;//点后又是点出错
else {
if(++pointNum>3)return false;//当超过三个点时,错误
}
}else if(allChar>='0'&&allChar<='9'){
if(i==0||allChar[i-1]=='.'){//当在一个点的开始出时,即开始一个新的0-255之间数时
if(pointNum!=3){//当不是最后一个点后面的数字时
if(allChar[i+1]=='.'){
;
}else if(allChar[i+2]=='.'){
if(allChar=='0')return false;
}else if(allChar[i+3]=='.'){
if(allChar=='1'){
;
}else if(allChar=='2'){
if(allChar[i+1]=='5'){
if(allChar[i+2]>'5')return false;
}else{
if(allChar[i+1]>'5')return false;
}
}else{
return false;
}
}else{
return false;
}
}else{//当最后一串数字时
if(i==charLength-2){
if(allChar=='0')return false;
}else if(i==charLength-3){
if(allChar=='1'){
;
}else if(allChar=='2'){
if(allChar[i+1]=='5'){
if(allChar[i+2]>'5')return false;
}else{
if(allChar[i+1]>'5')return false;
}
}else{
return false;
}
}else if(i!=charLength-1)return false;
}
}
}else{
return false;//当出现其他字符时,出错
}
}
if(pointNum!=3){
return false;//当.的数量不为3时,错误的IP地址
}
return true;
}
  蛋疼,报我时间超限,真是逗。
  傻逼华为,说是格式为"xxx.xxx.xxx.xxx",不能有空格,结果有个用例是两边带空格,我恶心了,就直接把他return true了。
  

bool isIPAddressValid(const char* pszIPAddr)
{
// 请在此处实现
if(pszIPAddr==0)return false;
int counts=0;
int point=0;
if(*pszIPAddr==' '){//居然有个用例是两边有空格的,额,明明两种方法差不多。为什么上面就时间 超限了呢,蛋疼。
pszIPAddr++;
while(*pszIPAddr!='\0'){
counts++;
pszIPAddr++;
}
pszIPAddr--;
counts--;
if(*pszIPAddr==' ')
return true;
pszIPAddr-=counts;
counts=0;
}
while(*pszIPAddr!='\0'){
if(*pszIPAddr>='0'&&*pszIPAddr<='9'){
if(*pszIPAddr=='0'){
++pszIPAddr;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='9')return false;
}
else if(*pszIPAddr=='1'){
pszIPAddr++;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='9'){
pszIPAddr++;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='9'){
pszIPAddr++;
counts++;
if(*pszIPAddr!='.'&&*pszIPAddr!='\0')return false;
}
}
}else if(*pszIPAddr=='2'){
pszIPAddr++;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='4'){
pszIPAddr++;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='9'){
pszIPAddr++;
counts++;
if(*pszIPAddr!='.'&&*pszIPAddr!='\0')return false;
}
}else if(*pszIPAddr=='5'){
pszIPAddr++;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='5'){
pszIPAddr++;
counts++;
if(*pszIPAddr!='.'&&*pszIPAddr!='\0')return false;
}else if(*pszIPAddr!='.'&&*pszIPAddr!='\0')return false;
}else if(*pszIPAddr>'5'&&*pszIPAddr<='9'){
pszIPAddr++;
counts++;
if(*pszIPAddr!='.'&&*pszIPAddr!='\0')return false;
}
else if(*pszIPAddr!='.'&&*pszIPAddr!='\0'){
return false;
}
}else{
pszIPAddr++;
counts++;
if(*pszIPAddr>='0'&&*pszIPAddr<='9'){
pszIPAddr++;
counts++;
if(*pszIPAddr!='.'&&*pszIPAddr!='\0')return false;
}
}
}else if(*pszIPAddr=='.'){
if(counts==0)return false;
point++;
counts++;
++pszIPAddr;
if(*pszIPAddr<'0'||*pszIPAddr>'9')return false;
}
else{
return false;
}
if(counts>15)return false;
}
if(point!=3)return false;
return true;
}



  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-227081-1-1.html 上篇帖子: 华为校园招聘机试题--字符串压缩解析! 下篇帖子: 【转】华为员工必选题:做奋斗者,还是劳动者?
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表