题目 1116: IP判断
时间限制: 1Sec 内存限制: 128MB 提交: 9809 解决: 4114
题目描述
在基于Internet的程序中,我们常常需要判断一个IP字符串的合法性。
合法的IP是这样的形式:
A.B.C.D
其中A、B、C、D均为位于[0, 255]中的整数。为了简单起见,我们规定这四个整数中不允许有前导零存在,如001这种情况。
现在,请你来完成这个判断程序吧^_^
输入
输入由多行组成,每行是一个字符串,输入由“End of file”结束。
字符串长度最大为30,且不含空格和不可见字符
输出
对于每一个输入,单独输出一行
如果该字符串是合法的IP,输出Y,否则,输出N
样例输入复制
1.2.3.4 a.b.c.d 267.43.64.12 12.34.56.bb 210.43.64.129 -123.4.5.6
样例输出复制
Y N N N Y N
#include<stdio.h>
#include<string.h>
void jisuan(char *a)
{
int i=0,s=0,l;
for(l=1;l<=4;l++)
{
int j=0,n=0,k;
char b[100];
while(a[i]!='.'&&a[i]!='\0')
{
if(a[i]<'0'||a[i]>'9')
{s=1;break;}
b[j]=a[i];
j++;i++;
}
if(b[0]=='0'&&j>1)s=1;
if(s==1)
{
printf("N\n");
break;
}
for(k=0;k<j;k++)
{
n=n*10+(b[k]-'0');
}
if(n>255||n<0)
{
s=1;printf("N\n");break;
}
i++;
}
if(s==0)
printf("Y\n");
}
int main()
{
char a[100][100],j=0,i;
while(scanf("%s",a[j])!=EOF)j++;
for(i=0;i<j;i++)jisuan(a[i]);
}