zoukankan      html  css  js  c++  java
  • HDU2206 IP的计算 【经典题】

    IP的计算

    Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 7479    Accepted Submission(s): 1457


    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

    合法的IP必然满足下面:
    1、字符仅仅包括0-9和‘.’。
    2、有且仅仅有3个‘.’。
    3、每格数字最多3位且不超过255;
    4、两个‘.’不能连在一起;

    5、第一个字符不是‘.’.


    #include <stdio.h>
    char str[102];
    int ok;
    
    int check(char ch){ 
    	if(ch >= '0' && ch <= '9') return 1;
    	if(ch == '.') return 2;
    	return 0;
    }
    
    int main(){
    	int dot, dignum, a, dotsum;
    	while(gets(str)){
    		dotsum = a = dot = dignum = 0;
    		for(int i = 0; str[i]; ++i){
    			ok = check(str[i]);
    			if(!ok) break;
    			if(ok == 1){
    				dot = 0;
    				++dignum;
    				a = a * 10 + str[i] - '0';
    				if(dignum > 3 || a > 255){
    					ok = 0; break;
    				}
    			}else{
    				dignum = a = 0;
    				++dot; ++dotsum;
    				if(dot > 1 || dotsum > 3){
    					ok = 0; break;
    				}
    			}
    		}
    		if(str[0] == '.' || dot || dotsum != 3) ok = 0;
    		printf(ok ? "YES
    " : "NO
    ");
    	}
    	return 0;
    }


  • 相关阅读:
    安全和加密
    awk
    CentOS7练习
    CentOS7系统引导顺序以及排障
    网络配置
    RAID阵列搭建
    LVM逻辑卷
    java-web——第九课 request
    java-web——第八课 JSTL的显示格式
    java-web——第七课 JSTL
  • 原文地址:https://www.cnblogs.com/claireyuancy/p/6719215.html
Copyright © 2011-2022 走看看