解题思路:





注意事项:


注意多行输入,并且注意每次遇到.都要判断前导0


参考代码:

#include<stdio.h>

int main()

{

char sz[100][30];

int n=0,t=0,i,j,flag;

while(~scanf("%s",sz[n]))   //控制多行输入

{

n++;

}



for(i=0;i<n;i++)

{

for(t=0,j=0,flag=1;sz[i][t]!='\0';t++)   //对数组元素依此判断,j判断前导0问题

{

if(sz[i][t]=='.') {t++;j=0;}   //如果遇到.就跳到下一个,并且j从新开始计数

if(sz[i][t+j]=='0') {flag=0;break;}

j+=30;                        //如果第一个数不是0,那就不存在前导0问题,改变j的值使上一个if不可能成立

if(sz[i][t]<'0'||sz[i][t]>'9') {flag=0;break;}   //将每个元素规定只能为正数,-也是会占一个空间,不在0~9范围内。

if(flag==0) break;

}

if(flag==1) printf("Y\n");

else printf("N\n");

}



return 0;

}

运行已通过。

点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论