- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 C 语言新手,我的学位需要完成一门 C 编程类(class)。希望标题有意义……我很难表达我的意思。我会在这里详细说明。
我现在面临的问题是双类型数据在应该被拒绝的情况下却能够在未被检测到的情况下通过程序。当提供的数字非常接近我设置的边界时,就会发生这种情况。
在这个作业中,为了获得 HD,我的代码必须具有与讲师相同的输出。该解决方案能够检测任何大于边界的数字,无论距离有多近。
基本上,程序会要求用户提供 0 到 4 之间的 GPA。我尝试了以下输入:4.01 拒绝4.001 被拒绝...4.000001 被拒绝但在 4.0000001 时,它被接受。这根本不应该发生。我很困惑。
这是我的代码:
double GPA=-1; /*Flags are being initialised*/
int GPAflag=1;
while(GPAflag){
char str[50];
char *ptr;
int isnum=1,n=0,i,point=0;
printf("Enter GPA>");
fflush(stdin);
gets(str);
n = strlen(str);
if(n==0){ /*string length is 0? There was no input, thus invalid*/
printf("Invalid GPA. ");
isnum=0;
}else{
for(i=0;i<n;i++) /*Validates numerical inputs, if not numerical, prompts user with error*/
if(!(str[i]>='0' && str[i]<='9')){
if(str[i]!='.'){
printf("Invalid GPA. ");
isnum=0;
break;
}else{
point++;
}
}
}
if(isnum){ /*If the input is a number, it may still be invalid*/
GPA=strtod(str, &ptr); /*The string is converted to a double*/
if(GPA>=0&&GPA<=4&&point<=1) /*If GPA is between 0 and 4, and the above is also satisfied (point=1), then the flag is 0 and thus a valid input*/
GPAflag=0;
else
printf("Invalid GPA. "); /*If not, it is still invalid*/
}
}
我个人认为这不会成为问题,但我真的很想知道为什么会发生这种情况,如果可能的话,想知道解决它的方法。
我可以简单地创建一个 FOR 循环:IF 前导数字是 4 并且有一个“.”-> 拒绝但这对我来说似乎是硬编码,我认为这只是一种解决方法而不是实际的解决方案。或者我可以将 IF 语句从“<=4”更改为“<4.0000000000000000000000...1”。在我看来,哪个应该失去分数...(如果我是标记者,我会为此扣分)
此外,我完全意识到函数“gets”是原始的,会导致许多问题(溢出......等)。我尝试过使用 fgets,但实现起来很痛苦...用 '\0' 替换 '\n' 等等等等...我们甚至没有学过 gets,更不用说 fgets 了。有没有更好的方法来实现fgets?也许有一个函数可以替换 '\n'?我已经尝试过,但它拒绝工作。
非常感谢任何帮助和提示!
最佳答案
OP 的真实代码使用的是 float GPA=-1;
,因此 GPA=strtod("4.0000001", &ptr);
产生了 GPA
由于 float
与 double
相比,精度限制更大,因此 code> 值恰好为 4.0。
通过使用double GPA;
,如发布的代码中所示,GPA=strtod("4.0000001", ...
和 GPA=strtod("4.000000001 ", ...
将返回一个略大于 4 的值。即使 GPA=strtod("4.00000000000001", ...
也可能返回一个略大于 4 的值。
在某些时候,double
的有限精度会将 GPA=strtod("4.0 muchdigits 001", ...
渲染为 4.0。限制精度的典型解决方案位数为 15 或更少。
(如果使用超过 15 个数字,可能会 mock 用户。)
关于C -- Double 类型数据 : Number slightly larger than allowed is able to slip through the conditions,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37350229/
现在我已经创建了一个额外的跨度来容纳一个条件。 568 || subKey == 0" ng-repeat="links in linksWrap.links">
一些 excel IF 语句可能会变得相当长,我正在寻找一种更简单的方法来编写它们。例如,如果我要写: If($B$4+13=7,$B$4+13,FALSE) 我认为它会更容易说: If($B$4+1
我有一个包含 FromDate 、 ToDate 、 VendorName 和 GoodsName 的表单,一旦一切为真,我需要显示结果 示例: FromDate="11/20/2019"、ToDat
我经常看到使用 !!condition 而不仅仅是常规条件的代码。即: if(!!value){ doSomething(); } 对比: if(value){ doSomething
这个问题有点模棱两可,这两个在汇编代码/性能方面是否等效: public void example{ do{ //some statements; if(condition)
在我看到的使用 Any 方法的 Linq 查询示例中,大约有一半是通过将其应用于 Where() 调用的结果来实现的,另一半则直接将其应用于集合。这两种样式是否总是等效的,或者在某些情况下它们可能会返
这个问题在这里已经有了答案: What does !!(x) mean in C (esp. the Linux kernel)? (3 个答案) 关闭 9 年前。 我见过人们使用带有两个 '!'
我对部署在生产环境中的应用程序进行了线程转储,该应用程序使用 logback。我不是分析线程转储的专家,但是,我必须这样做。正在学习,网上也看了一些文章。 下面是真正的线程转储: "logback-8
在 SQL 中(特别是 Postgres): 子句 where not foo='bar' in case foo is null 评估为某种 null,导致该行不是包含在结果中。 另一方面,子句 w
是不是类似于has and condition with join和where condition after join? 例如 对于以下两个查询,它会给我相同的结果吗 1) SELECT COUNT
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
如果您调用某个函数,并且该函数在发生错误时返回 NULL(例如,想想 malloc() 或 fopen()),两个更好: FILE *fp = fopen(argv[0], "r"); if (fp
我正在使用 Azure 数据工厂 V2,我需要在父检查验证中实现两级检查。例如:如果条件一为真,那么我需要检查条件 2。并且,如果条件 2 为真,则检查条件 3。 这是一种分层检查。当我在父 IF 条
使用 Linq to Entities 有以下区别吗? db.EntityName.Where(a => a.Id == id).FirstOrDefault(); db.EntityName.Fir
我有一种情况,我已经用两种不同的方式解决了,但想知道人们对这些选项的看法,以及他们是否有其他选择...... 系统正在处理数据的“间隔”。 所有数据都分配到一个“区间” 该间隔由事实表 中的“inte
我有包含字段 Amount, Condition1, Condition2 的表格。 例子: Amount Condition1 Condition2 ---------------------
我正在尝试在 Netbeans 中制作一个简单的 MySQL、Java JDBC Web 应用程序。我希望根据当前 session 中的状态变量显示不同的内容。我尝试了以下方法: 首先,我在 .jsp
我想为 postnuke cms 设计一个主题。 并希望在模板文件中使用 css 条件。 postnuke 使用类似 smarty 的标签 .... 所以当我使用 .... 它给出了一些关于标签的错误
我想问一下asyncio.Condition .我对这个概念并不熟悉,但我从学生时代就知道并了解锁、信号量和队列。 我找不到很好的解释或典型的用例,只是 this example .我看了看来源。核心
我想知道如何在不在语句中重做相同查询两次的情况下处理 SQL 比较。这是我要找的: SELECT columnName10, IF( SELECT columnName20 FROM Othe
我是一名优秀的程序员,十分优秀!