IP判断

Description

在基于Internet的程序中,我们常常需要判断一个IP字符串的合法性。
合法的IP是这样的形式:
A.B.C.D
其中A、B、C、D均为位于[0, 255]中的整数。为了简单起见,我们规定这四个整数中不允许有前导零存在,如001这种情况。
现在,请你来完成这个判断程序吧^_^

Input

输入由多行组成,每行是一个字符串,输入由“End of file”结束。
字符串长度最大为30,且不含空格和不可见字符

Output

对于每一个输入,单独输出一行
如果该字符串是合法的IP,输出Y,否则,输出N

Sample Input

1.2.3.4
a.b.c.d
267.43.64.12
12.34.56.bb
210.43.64.129
-123.4.5.6

Sample Output

Y
N
N
N
Y
N

个人思路:通过if语句实现判断正误;通过三个“.”将一个字符串分成4个字符串,期间测试是否含有非字母字符,四个部分的数字均小于255,4个及4个字符以上的字符串均不合题意,然后判断前导0的存在与否,最后判断4部分是否都在【0,255】之间。

示例代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
int main()
{
//    freopen("1.txt", "r", stdin);
     char str[30];
     int flag[4] = {0};
     int i, j = 0, k = 0;
     int len;
     int oj1 = 0, oj2 = 0;
     int digit;
     while ( scanf ( "%s" , str) != EOF)
     {
         char ip[4][10] = {0};
     j=0; k=0; oj1=0; oj2 = 0; flag[0] = 0;
     len = strlen (str);
     for (i=0; i<len; i++)
     {
         if (str[i] == '.' )
         {
             j++;
             flag[j] = i+1;
             k = 0;
         }
         else
         {
             if ( isdigit (str[i]) == 0)
             {
                 printf ( "N\n" );
                 oj2 = 1;
                 break ;
             }
             else
             {
             if (str[i] == '0' && str[i+1] != '.' )
               {
                 if (i+1 == len)
                     continue ;
                 printf ( "N\n" );
                 oj2 = 1;
                     break ;
               }
               else
               {
                 ip[j][k] = str[i];
                 k++;
                 if (k>=5)
                 {
                     printf ( "N\n" );
                     oj2 = 1;
                     break ;
                 }
               }
 
             }
         }
     }
     if (oj2 == 0)
     {
     for (i=0; i<4; i++)
     {
         digit = atoi (ip[i]);
         if (digit >= 0 && digit <= 255 )
             {
                 oj1 = 0;
             }
         else
             {
                 oj1 = 1;
                 break ;
             }
     }
     if (oj1 == 1)
     {
         printf ( "N\n" );
     }
     else
     {
         printf ( "Y\n" );
     }
     }
     }
     return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值