美文网首页iOS算法数据结构和算法分析
算法题:判断字符串是否为 ipv4 地址

算法题:判断字符串是否为 ipv4 地址

作者: 酷酷的哀殿 | 来源:发表于2016-10-22 15:16 被阅读346次
#include <stdio.h>

typedef char bool;
#define true 1
#define false 0

/**

   1.判断字符串是否形如“192.168.1.1”

   2.字符串两端含有空格视为合法ip,形如“    192.168.1.1    ”

   3.字符串中间含有空格视为非法ip,形如“192.168. 1.2”

   4.字符串0开头视为不合法ip,形如192.168.01.1

   5.字符串0.0.0.0视为合法ip
 */

bool checkIpv4(const char *ip){
    printf("检验对象是:%s\n", ip);
    if(NULL == ip) {
        return false;
    }
    const char *q = ip;     //字串指针
    unsigned short int s = 0, count = 0, digitNumber = 0;  //s是字串转化为的整型,count是 . 的个数, digitNumber 是 . 之间的数量
    bool hasZero = false;
    // 开头有空格
    while(' ' == *q) {
        q++;
    }

    while('\0' != *q) {
        if('.' == *q) {
            // . 前面没有任何值,则非法
            if(digitNumber == 0) {
                return false;
            }
            s = 0;
            digitNumber = 0;
            count++;

            hasZero = false;

            q++;

            continue;
        }

        // 值非法
        if(*q < '0' || *q > '9') {
            // 结尾空格
            if(' ' == *q && 3 == count) {
                const char *qq = q;
                while(' ' == *qq) {
                    qq++;
                }
                return '\0' == *qq;
            } else{
                return false;
            }
        }

        int x = *q - '0';
        s = s*10 + x;

        // 0.0.0.0 合法, 00.0.0.0 不合法
        if(0 == s) {
            if(hasZero) {
                return false;
            } else{
                hasZero = true;
            }
        }

        if(s > 255) {
            return false;
        }
        digitNumber++;
        q++;
    }
    return (3 == count);
}

int main(void){
    {
        const int count = 10;
        char *ip[count] = {"0.0.0.0", "255.255.255.255", "0.10.0.0", " 1.1.1.1", "1.1.1.1 ", " 1.1.1.1 "};
        for(int i = 0; i < count; i++) {
            if(checkIpv4(ip[i]))
                printf("该地址是IPv4地址\n");
            else
                printf("该地址不是IPv4地址\n");
        }
    }
    printf("\n\n");
    {
        const int count = 10;
        char *ip[count] = {"1.1.1. 1", "1..2.3", "00.1.1.1", "a.1.1.1", };
        for(int i = 0; i < count; i++) {
            if(checkIpv4(ip[i]))
                printf("该地址是IPv4地址\n");
            else
                printf("该地址不是IPv4地址\n");
        }
    }
    return 0;
}

相关文章

  • 算法题:判断字符串是否为 ipv4 地址

  • 2020-03-05 ios面试题

    需要说明有2个算法题: 1.用二分法开根号; 2. 判断字符串是否符合ipv4; 这遍文档很全https://ww...

  • Codewars编程套路练习:验证IPv4地址

    问题描述 设计一个算法,判断点分十进制格式的IPv4地址是否符合协议要求。函数的输入限制为一个字符串。 合理的输入...

  • Python面试题: 判断IP地址是否合法

    题目: 给出一个字符串, 判断其是否是是合法的IP(IPv4)地址思路 将字符串按"."分割成4段得到一个列表 逐...

  • 468. Validate IP Address

    验证输入的字符串是否是有效的IP地址: IPv4 地址由十进制数和点来表示,每个地址包含4个十进制数,范围为 0-...

  • Leetcode468. 验证IP地址

    题目 编写一个函数来验证输入的字符串是否是有效的 IPv4 或 IPv6 地址。 IPv4 地址由十进制数和点来表...

  • c语言验证IP地址

    1.问题描述 编写一个函数来验证输入的字符串是否是有效的 IPv4 或 IPv6 地址 IPv4 地址由十进制数和...

  • java 正则 常用

    1、判断字符串 是否为纯字母 2、判断字符串 是否为纯数字 3、判断字符串 是由字母和数字组成 4、判断字符串 是...

  • SOP.Java工具集

    判断字符串是否为空 StringUtils 判断对象是否为空 ObjectUtils 将字符串转换为字符串数组

  • iOS【NSString基本方法】

    判断字符串是否包含数字 判断字符串是否包含英文字母 判断字符串是否包含数字与字母 去掉首尾空格字符 判断是否为空 ...

网友评论

    本文标题:算法题:判断字符串是否为 ipv4 地址

    本文链接:https://www.haomeiwen.com/subject/cxbwyttx.html