`

hdu 2206 IP的计算

阅读更多
IP的计算
Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2686    Accepted Submission(s): 488


Problem Description
在网络课程上,我学到了很多有关IP的知识。IP全称叫网际协议,有时我们又用IP来指代我们的IP网络地址,现在IPV4下用一个32位无符号整数来表示,一般用点分方式来显示,点将IP地址分成4个部分,每个部分为8位,表示成一个无符号整数(因此不需要用正号出现),如192.168.100.16,是我们非常熟悉的IP地址,一个IP地址串中没有空格出现(因为要表示成一个32数字)。
但是粗心的我,常常将IP地址写错,现在需要你用程序来判断。



Input
输入有多个case,每个case有一行,不超过100个字符。


Output
对于每个case,判断输入的IP是否正确,如果正确输入YES,否则NO。


Sample Input
192.168.100.16


Sample Output
YES


Author
wangye


Recommend
wangye


看似简单的东西是有陷阱的,主要注意以下四点:
<1> 检验时滤掉前导和后缀空格
<2> 4个段的数字位数不能超过3位,例如 000.000.000.000是正确的,但
     0000.000.000.000就是错误的
<3> 分隔符点的个数是3,多了少了都不行
<4> 每个段值不能超过255



我的代码,很长,很浪费内存,但还能过,记录一下吧。
#include <stdio.h>
#include <string.h>

int check_num(char s[], int st, int end)
{
    int i, k = 0, tag = 0;
    if(end - st > 3)
        return 0;
    for( i = st; i < end; i++)
    {
        if(s[i] >= '0' && s[i] <= '9')
        {
            k = k * 10 + s[i] - '0';
            tag = 1;    
        }    
        else
            return 0;
    }
    if(k > 255 || tag == 0)
        return 0;
    //printf("k = %d\n", k);
    return 1;
}
int check_ip(char s[])
{
    int len = strlen(s);
    int st, end;
    int dotp[4], ip[4];
    int dn = 0;
    int i, j, k, res;
    for(i = 0; s[i] == ' '; i++) 
        ;  // process the backspace before number
    st = i;
    
    for(i = len - 1; s[i] == ' '; i--)
        ; //process the backspace after number
    end = i + 1;
    
    k = 0;
    for(i = st; i < end; i++)
    {
        if(s[i] == '.')
        {
            dn++;
            if(dn > 3) // more than 3, break
                break;
            dotp[k++] = i;
        }
    }
    if(dn != 3)  // dot number is not 3
    {
            return 0;
    }
    for(i = 0; i < 4; i++)
    {
        switch(i)
        {
            case 0: 
                    res = check_num(s, st, dotp[0]);
                    break;
            case 1: 
            case 2: 
                    res = check_num(s, dotp[i - 1] + 1, dotp[i]);
                    break;
            case 3:
                    res = check_num(s, dotp[i - 1] + 1, end);
                    break;
        }
        if(res == 0)
        {
                return 0;
        }
    }    
    return 1;
}

int main()
{
    char s[101];
    int res;
    while(gets(s) != NULL)
    {
        res = check_ip(s);
        if(!res)
            printf("NO\n");
        else
            printf("YES\n");
    }
    
    return 0;    
}

分享到:
评论

相关推荐

    HDU_2010.rar_hdu 2010_hdu 20_hdu acm20

    此外,为了优化解决方案,参赛者可能会考虑对数字范围进行优化处理,避免不必要的计算,以提高程序效率。在ACM竞赛中,代码的运行时间和空间复杂度都是评判的重要因素。 总的来说,这个压缩包提供了一个学习和研究...

    hdu.rar_hdu

    HDU(杭州电子科技大学在线评测系统)是一个深受程序员喜爱的在线编程练习平台,它提供了丰富的算法题目供用户挑战,帮助他们提升编程技能和算法理解能力。"hdu.rar_hdu"这个压缩包文件很可能是某位程序员整理的他在...

    hdu1250高精度加法

    ### hdu1250高精度加法 #### 背景介绍 在计算机科学与编程竞赛中,处理大整数运算(特别是加法、减法、乘法等)是常见的需求之一。当数字的位数超过了标准数据类型(如`int`、`long`等)所能表示的最大值时,就需要...

    HDU DP动态规划

    动态规划通常用于优化多阶段决策过程,通过将问题分解为更小的子问题并存储子问题的解来避免重复计算,从而提高效率。 【描述】提到的"HDU的一题"可能是指HDU(杭州电子科技大学)在线判题系统中的一道动态规划题目...

    ACM HDU题目分类

    ACM HDU 题目分类 ACM HDU 题目分类是指对 HDU 在线判题系统中题目的分类,总结了大约十来个分类。这些分类将有助于编程选手更好地理解和解决问题。 DP 问题 DP(Dynamic Programming,动态规划)是一种非常重要...

    HDU1059的代码

    HDU1059的代码

    hdu1001解题报告

    hdu1001解题报告

    HDU杭电 计算机网络实验报告

    这份"HDU杭电 计算机网络实验报告"压缩包提供了丰富的实验材料,涵盖了多个关键的网络技术,包括交换机配置、路由协议、地址转换(NAT)、访问控制列表(ACL)以及动态主机配置协议(DHCP)等。以下是这些实验报告所...

    hdu 1574 passed sorce

    hdu 1574 passed sorce

    hdu2101解决方案

    hdu2101AC代码

    HDU_软工_计组实验1~8

    【标题】"HDU_软工_计组实验1~8"所涵盖的知识点主要集中在计算机组织(简称计组)的实践操作层面,这通常包括对计算机硬件结构、指令系统、存储器体系、数据表示以及处理器工作原理等基础知识的深入理解和应用。...

    hdu 300+ AC 代码

    HDU 300+ AC 代码集合是一个包含超过300个已通过验证的算法解决方案的资源,这些代码主要用于解决各类计算机编程竞赛中的问题。这些竞赛通常由杭州电子科技大学(HDU)主办,旨在提升参赛者的算法设计、编程和问题...

    HDU题目java实现

    【标题】"HDU题目java实现"所涉及的知识点主要集中在使用Java编程语言解决杭州电子科技大学(HDU)在线评测系统中的算法问题。HDU是一个知名的在线编程竞赛平台,它提供了大量的算法题目供参赛者练习和提交解决方案...

    ACM HDU

    【ACM HDU】指的是在ACM(国际大学生程序设计竞赛,International Collegiate Programming Contest)中,参赛者在杭州电子科技大学(Hangzhou Dianzi University,简称HDU)的在线评测系统上完成并已解决的题目集合...

    杭电ACMhdu1163

    【标题】:杭电ACMhdu1163 【描述】:这是一道源自杭州电子科技大学(Hangzhou Dianzi University,简称HDU)的ACM编程竞赛题目,编号为1163。这类问题通常需要参赛者利用计算机编程解决数学、逻辑或算法上的挑战,...

    hdu 5007 Post Robot

    hdu 5007 Post Robot 字符串枚举。 暴力一下就可以了。

    hdu动态规划算法集锦

    根据提供的信息,我们可以总结出以下关于“hdu动态规划算法集锦”的知识点: ### 动态规划基础概念 动态规划是一种解决多阶段决策问题的方法,它通过将原问题分解为互相重叠的子问题,利用子问题的解来构建原问题...

    hdu1290解题报告

    ### hdu1290解题报告 #### 题目背景与意义 此题作为对杭州电子科技大学五十周年校庆的献礼,通过一道趣味性的数学问题来庆祝这一重要时刻。题目背景设置在一个充满想象力的情境下,即如何通过不同数量的切刀将一个...

    hdu acm1166线段树

    hdu 1166线段树代码

    Hdu1000—2169部分代码

    HDU是杭州电子科技大学(Hangzhou Dianzi University)举办的一个在线编程竞赛平台,全称为HDU Online Judge。ACM是国际大学生程序设计竞赛(International Collegiate Programming Contest)的缩写,是一个全球性的...

Global site tag (gtag.js) - Google Analytics