[华为机试练习题]5.IP地址判断有效性

简介:

题目

判断输入的字符串是不是一个有效的IP地址

详细描述:

请实现如下接口
boolisIPAddressValid(constchar* pszIPAddr)
输入:pszIPAddr 字符串
输出:true 有效的IP地址,false,无效的IP地址

约束

输入IP为XXX.XXX.XXX.XXX格式
字符串两端含有空格认为是合法IP
字符串中间含有空格认为是不合法IP
类似于 01.1.1.1, 1.02.3.4 IP子段以0开头为不合法IP
子段为单个0 认为是合法IP,0.0.0.0也算合法IP

知识点: 字符串
题目来源: 111
练习阶段: 中级

代码

/*---------------------------------------
*   日期:2015-06-25
*   作者:SJF0115
*   题目:IP地址判断有效性
*   来源:华为上机
-----------------------------------------*/
#include <iostream>
#include <cstring>
using namespace std;

bool isIPAddressValid(const char* pszIPAddr)
{
    if(pszIPAddr == NULL)
    {
        return false;
    }//if
    int size = strlen(pszIPAddr);
    // 去除前导0
    int start = 0;
    while(pszIPAddr[start] == ' ')
    {
        ++start;
    }//while
    // 去除后导0
    int end = size - 1;
    while(pszIPAddr[end] == ' ')
    {
        --end;
    }//while
    int num = 0;
    int pointCount = 0;
    int first = start;
    for(int i = start;i <= end+1;++i)
    {
        if(pszIPAddr[i] >= '0' && pszIPAddr[i] <= '9')
        {
            num = num * 10 + pszIPAddr[i] - '0';
        }//if
        else if(pszIPAddr[i] == '.' || i == end + 1)
        {
            if(i == start || (pszIPAddr[i-1] < '0' || pszIPAddr[i-1] > '9'))
            {
                return false;
            }
            // 验证.个数
            if(pszIPAddr[i] == '.')
            {
                ++pointCount;
                if(pointCount > 3)
                {
                    return false;
                }//if
            }//if
            // 验证数据
            if(num > 255 || num < 0)
            {
                return false;
            }//if
            // 以0开头且不为0 例如:023
            if(num != 0 && pszIPAddr[first] == '0')
            {
                return false;
            }//if
            first = i+1;
            num = 0;
        }//else
        else
        {
            return false;
        }//else
    }//for
    if(pointCount != 3)
    {
        return false;
    }
    return true;
}
目录
相关文章
|
4月前
【每日一题Day353】LC2525根据规则将箱子分类 | 模拟
【每日一题Day353】LC2525根据规则将箱子分类 | 模拟
14 0
|
5月前
|
算法
代码随想录算法训练营第二十七天 | LeetCode 93. 复原 IP 地址、78. 子集、90. 子集 II
代码随想录算法训练营第二十七天 | LeetCode 93. 复原 IP 地址、78. 子集、90. 子集 II
34 0
|
10月前
|
机器学习/深度学习 算法
代码随想录训练营day28| 93.复原IP地址 78.子集 90.子集II
代码随想录训练营day28| 93.复原IP地址 78.子集 90.子集II
(模拟)(枚举)acwing蓝桥杯1245. 特别数的和
(模拟)(枚举)acwing蓝桥杯1245. 特别数的和
44 0
|
安全 算法 C++
蓝桥杯练习题二 - 合并检测(c++)
蓝桥杯练习题二 - 合并检测(c++)
129 0
随机练习题:浅浅固定思路
随机练习题:浅浅固定思路
248 0
代码随想录刷题|LeetCode 93.复原IP地址 78.子集 90.子集II
代码随想录刷题|LeetCode 93.复原IP地址 78.子集 90.子集II
|
Java Python
每日一题:1894.找到需要补充粉笔的学生编号 简单的模拟题目,注意求余的技巧!
每日一题:1894.找到需要补充粉笔的学生编号 简单的模拟题目,注意求余的技巧!
85 0
Stack 经典面试题之判断字符串是否合法
每次说到栈,贪吃的阿粉就会想起烙饼这件事。每次阿粉的母亲烙饼的时候,先烙好的饼会放在最下面,后面烙好的饼会放在上面,还在烙饼的时候,我就想吃所以被我吃到的就是最上面的饼。