0.5的整数倍

Time Limit: 1000MS   Memory Limit: 100K
Total Submissions: 1   Accepted: 1

Description

输入一个实数 判断是否为0.5的整数倍

Input

输入一个整数N(1<=N<=1000) 表示输入N个数

第二行开始 输入个数 算上小数点最多1000位 共N行

Output

如果此数为0.5的整数倍则输出Yes 否则输出No

Sample Input

3

0.500000000000000000000000000000000000000000000001
-12.50000000000000000000000000000000000000000

+123456879897987789987.0

Sample Output

No
Yes
Yes

个人理解:

用简单的扩大缩小 会导致数据不准确

因此用 字符串比较合适

但是字符串虽然让位数没了限制 但是 如果用户输入的不是数字

或者 有 +      -      .5       .       0.        0.500000          .0000000      .50000000    等情况都需要考虑到

代码C语言:

# include <stdio.h>
int gainchar(char *a,int max);//对*a输入范围[1,max]返回 小数点的位置 如果没有小数点 返回0
int GET(char S[],int A);//S为字符串 A为小数点的位置 是0.5整数倍返回1 否则返回0
# define N 1001   //录入N位数
char A[N+1];
int main()
{int n,F;char B[][4]={"No","Yes"};scanf("%d",&n);while(n--){F=GET(A,gainchar(A,N));puts(B[F]);}return 0;
}
int GET(char S[],int A)//S为字符串 A为小数点的位置 是0.5整数倍返回1 否则返回0
{int C=-1;while(S[++C]);  //C=B的长度if(!A||A==C)return 1;//如果小数点没有或者在最后的位置if(S[A]=='5'||S[A]=='0')//如果小数点后面是'5'或者'0'{while(A<C&&S[A+1]=='0')A++;//继续比较是不是'0'return A>=C-1;//如果比较最后A>=C-1则比较完毕都符合题意}return 0;//如果上述都不行 返回0
}
int gainchar(char *a,int max)//对*a输入范围[1,max]
{int B,c,Flag,i,j,k,S;do{j=i=-1;k=Flag=i=0;do{a[max]=B=c=0;while((a[c++]=getchar())!='\n'&&c<max);if(a[c-1]!='\n')while(getchar()!='\n'&&++B);else a[--c]=0;if(B||c&&c<1)printf("您录入的字符串长度:%d字节\n只录入(1--%d)个字节!\n",B+c,max);}while(B||c>max||c<1);while(++i<c){if((a[i]>'9'||a[i]<'0')){if(a[i]=='.'){k++;    //k记录小数点个数j=i;}else if(!i&&(a[0]=='-'||a[0]=='+'));else{Flag++;break;}}}if(Flag||k>1) printf("输入的数字不合法!");  //当小数点多于1个或者有的不是数字时}while(Flag||k>1);return j+1;    //返回下标
}

下面的的代码 是完善输入输出的:

# include <stdio.h>
/*判断任何一个数是否为0.5的整数倍  zhagoodwell*/
int gainchar(char *a,int max);//输入数字 保存在a里 并返回 小数点的位置 如果没有小数点 返回0
# define N 1001   //想录入X位数 包括+-号和小数点  就将其改为 X+1
int main(){
char B[N];
int A,C;
do{
C=-1;
A=gainchar(B,N);  //A储存小数点下标 非数组下标
while(B[++C]);  //C=B的长度
if(!A||A==C)
printf("YES!\n");
else if(B[A]=='5'||B[A]=='0')
{
while(A<C&&B[A+1]=='0')
A++;printf("%s!\n",A>=C-1?"YES":"NO");
}
else
printf("NO!\n");
}while(C);
return 0;
}
int gainchar(char *a,int max)//对*a输入范围(min,max),如果字符数组中存在'\n',将其改为'\0'
{
int c,Flag,i,j,k,S;
do{
printf("输入数字(1--%d位):\n",max-1);
do{
j=c=-1;         //初始化数据
k=Flag=i=S=0;
fgets(a,max,stdin);
while(a[++c]);
c=a[c-1]=='\n'&&c<max?c-1:c;
if(c>=max-1)
while(getchar()!='\n')S++;     //输出的位数多于N-1时会除去多余的
else
a[c]='\0';
if(S||c&&(c>max||c<1))//如果用户只输入'\n'则不提示输入错误,否则提示错误
printf("输入长度有误,请重新输入!\n注:(1--%d)位:\n",max-1);
}while(S||c>max||c<1);
while(i<c)
{
if((a[i]>'9'||a[i]<'0'))
{
if(a[i]=='.')
{
k++;    //k记录小数点个数
j=i;
}
else if(!i&&(a[0]=='-'||a[0]=='+'));
else{
Flag++;
break;
}
}
i++;
}
if(Flag||k>1)   //当小数点多于1个或者有的不是数字时
printf("输入的数字不合法!");
}while(Flag||k>1);return j+1;    //返回下标
}

附加小代码判断字符串是否为汉字:

可能有人会说很简单,因为C语言中汉字的ASCLL码都是负的,但是 如果用户输入的是中文标点符号  那么单纯的依靠正负是不行的
# include <stdio.h>
# define N 13
int Chinese(char *a,int min,int max);   //min为偶数 max一定要为奇数
int main(){char a[2][N];printf("%d字节—%s\n",Chinese(a[0],2,13),a[0]);printf("%d字节—%s",Chinese(a[1],2,13),a[1]);
}
int Chinese(char *a,int min,int max)
{int c,i,j,k,p;char key[23][3]={"。","】","【","!","…","?","《","》",",","{","}","(",")","¥","‘","’",":",";","—","”","“","、","·"};printf("注:一个汉字两个字节\n");do{printf("输入(%d--%d)个汉字:多余的汉字将自动清除:\n",min/2,max/2);do{c=i=-1;fgets(a,max,stdin);while(a[++c]);c=(a[c-1]=='\n')&&c<max?c-1:c;if(c>=max-1)while(getchar()!='\n');else a[c]='\0';if(c&&(c>max||c<min))printf("输入的汉字个数不合法!请重新输入:\n");}while(c>max||c<min);while(a[++i]<0&&i<c);if(i-c)p=0;elsefor(k=j=i=0,p=1;p&&k<23;i=j=0,k++){while(i<c&&j<2)if (a[i]==key[k][j]){++i;++j;}else{i-=j-1;j=0;}if(j==2&&!(i%2))p=0;}if(!p)printf("您的输入中有的不是汉字!\n请重新");}while(!p);return c;
}
功能好不好试了才知道。

编程判断一个实数(任何位数)是否为0.5的整数倍相关推荐

  1. 试编程判断输入的正整数是否既是5又是7的整数倍,若是输出“YES“,否则输出“NO“。

    #include <stdio.h> void main() {int n;printf("请输入一个正整数:\n");scanf("%d",&am ...

  2. 试编程判断输入的正整数是否既是5又是7的整数倍,若是输出“yes”,否则输出“no”。

    package Experiment.Java.test4;import java.util.Scanner;public class test03 {public static void main( ...

  3. java整除_java编程判断一个整数能否被9整除

    展开全部 1.可以使用下面这个表达式来进行计算62616964757a686964616fe4b893e5b19e31333431333962 if(n%9==0){ System.out.print ...

  4. python任意输入一个正整数、判断该数是否为素数_Python编程判断一个正整数是否为素数的方法,python素数...

    Python编程判断一个正整数是否为素数的方法,python素数 本文实例讲述了Python编程判断一个正整数是否为素数的方法.分享给大家供大家参考,具体如下: import string impor ...

  5. python任意输入一个正整数、判断该数是否为素数_Python编程判断一个正整数是否为素数的方法...

    本文实例讲述了Python编程判断一个正整数是否为素数的方法.分享给大家供大家参考,具体如下: import string import math #判断是否素数的函数 def isPrime(n): ...

  6. python输入一个自然数、判断是否为素数_Python编程判断一个正整数是否为素数的示例代码分享...

    这篇文章主要介绍了Python编程判断一个正整数是否为素数的方法,涉及Python数学运算相关操作技巧,需要的朋友可以参考下 本文实例讲述了Python编程判断一个正整数是否为素数的方法.分享给大家供 ...

  7. python输入一个自然数、判断是否为素数_Python编程判断一个正整数是否为素数的方法...

    本文实例讲述了Python编程判断一个正整数是否为素数的方法.分享给大家供大家参考,具体如下: import string import math #判断是否素数的函数 def isPrime(n): ...

  8. Python课堂笔记之判断一个数组中是否含有数字0

    判断一个数组中是否含有数字0的3种方法: lst1=[1,3,4] lst2=[0,6,7] lst3=[[1,3,4],[0,6,7]]#1.如果有0,True for i in range(2): ...

  9. C语言编译能否被七整除,C++编程判断一个整数能否被3、5、7整除的几种方法

    今天开始试着自己找一些试题做,遇到这样一道题: 编程实现输入一个整数,判断其能否被3.5.7整除,并输出以下信息之一: (1)能同时被3.5.7整除: (2)能被其中两个数(要指出哪两个)整除: (3 ...

最新文章

  1. VS2013自带的Browser Link功能引发浏览localhost网站时不停的轮询
  2. mysql同步binlog_利用MySQL的Binlog实现数据同步与订阅(下)
  3. ​嵌入式开发为什么选择C语言?
  4. ELK和EFK的区别
  5. Mysql你应该要懂索引知识
  6. C#(WPF)为Grid添加实线边框。
  7. 李天平: 技术以外的功夫
  8. Bootstrap_导航
  9. git 设置忽略文件类型 gitignore
  10. 计算机科学与技术实践教学,计算机科学与技术实践教学方法_精编版.doc
  11. GetRows的用法详解
  12. 2020年百度之星程序设计大赛-初赛一(Drink、GPA、Dec)
  13. 递归实现斐波那契数列(Java)
  14. 关于Python中rank()函数的理解
  15. 全国25省市“智慧路灯”项目大汇总!
  16. DISALLOW_COPY_AND_ASSIGN DISALLOW_IMPLICIT_CONSTRUCTORS.
  17. Matlab气液相界面,MATLAB,气液相平衡程序,求帮忙改一下。
  18. xz2显示无法连接服务器,微端网页版无法登入问题解决方法
  19. Android CardView卡片布局详解(八)
  20. 2021数据库课程设计培训笔记:【JAVA】部分

热门文章

  1. echarts 矩形填充占比图treemap
  2. plc程序 linux,plc编程开发流程
  3. MT4 api跟单软件分享
  4. MySQL每天定时备份
  5. 网络钓鱼技术解析与安全防护措施
  6. 监控软件自动发现功能和监控软件分布式监控配置
  7. [论文]基于模型的细长体欠驱动水下机器人输出反馈控制:理论与实验
  8. 手机软件游戏安装方法(详细图文教程)-windows mobile系统PPC也通用
  9. 按键精灵手机助手连接安卓模拟器
  10. C#学习--dotnetbar控件学习