milk


私信TA

用户名:Soymilk

访问量:6875

签 名:

算法好难啊

等  级
排  名 85
经  验 9359
参赛次数 5
文章发表 10
年  龄 0
在职情况 学生
学  校 interesting
专  业

  自我简介:

#include <stdio.h>
#include <string.h>
#include <math.h>
int deal(char s[],int n);//函数解决
int main(){
 char s[30];
 while(~scanf("%s",s)){
  if(deal(s,strlen(s)))
  printf("Y\n");
  else
  printf("N\n");
 }
 return 0;
}
int deal(char s[],int n){
 int i,j,count,sum,t;
 char ans[10];//存储数据 
 for(i=0;i<n;i++){//先跑一遍,把最不可能的排除 
  if(s[i]=='\n'||s[i]=='.')
   continue;
  if(s[i]>'9'||s[i]<'0')
   return 0;
 }
 count=sum=0;
 for(i=0;i<n;i++){//第二次,判断范围 
  if(s[i]=='.'||s[i]=='\n'){//存数据——解析数据——存数据 
   for(j=0;j<count;j++){
    sum+=(ans[count-j-1]-'0')*pow(10,j);
   }
   if(sum>255)return 0;
   sum=count=0;
  }
  ans[count++]=s[i];
 }
 return 1;
}
 

0.0分

0 人评分

  评论区

  • «
  • »