- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在做 CS50 问题集 1 - 现金时,我在尝试编写代码时遇到了以下问题。我已将变量声明为整数。为什么它仍然发生?非常感谢您的帮助。
“二进制表达式的无效操作数(‘float’和‘float’)”
#include <stdio.h>
#include <cs50.h>
#include <math.h>
int main(){
float owe_in_dollars;
float owe_in_cent;
int coin_count = 0;
do
{
owe_in_dollars = get_float("Change: ");
}while(owe_in_dollars<0);
owe_in_cent = (int)(owe_in_dollars*100);
if (owe_in_cent%(int)25 > 0){
coin_count++;
}
printf("%i", coin_count);
}
最佳答案
这段代码有几个问题,但我认为产生编译器错误的特定问题是
if (owe_in_cent%(int)25 > 0){
owe_in_cent
是一个 float
。它没有理由是 float ,因为您已将它分配给一个整数值。但是你将它声明为 float
,所以它就是这样。 25
是一个 int
,因此将它转换为 int
没有任何意义,但无论是否进行转换,它都会被转换为float
以便用 owe_in_cent
进行算术运算,因为所有算术运算符都要求操作数的类型相同。搜索“通常的算术转换”以获取详细信息,但归根结底,这些自动转换始终是整数 → float ,而不是 float → 整数。
然后问题就出现了,因为 %
运算符要求它的操作数是整数,而不是 float 。有一个数学函数可以计算浮点模数,但您确实需要整数运算,所以最好的办法是将 owe_in_cent
设为 int
而不是 float
。
实际上,您真的应该养成对浮点值使用 double
的习惯。 float
非常不精确,除了在视频芯片和嵌入式处理器中,使用如此不精确的表示是没有意义的。它不会为您节省任何东西。
最后,记住关于 float 的两个重要事实:
它不能精确表示分母不是二的幂的分数。换句话说,5.25 有精确表示,因为 .25 是四分之一,是 2 的幂,但 5.26 不能精确表示,最终会是一个略大于或略小于 5.26 的数字。当您将该数字乘以 100 时,您最终会得到略多于或略小于 526 的结果。
将 float 转换为整数只会去掉小数部分,无论它多么接近 1.0。因此,例如,(int)525.9997
是 525,而不是 526。您应该能够看到可能产生的问题。
有一个名为round
的库函数它将 float 四舍五入为最接近的整数,这可能是您想要的。
关于c - 使用 C 时面对 'invalid operands to binary expression (' float' 和 'float' )',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55876843/
我正在尝试为一个简单的数学 Vector 类重载 += 运算符,以对两个 vector 的元素求和,如下所示: vector1 += vector2 部分Vector2D.h: #ifndef _VE
我正在尝试在 ASM 中编写一个简单的 for 循环。我需要访问两个数组,它们是在 C++ 代码片段之外编写的(即 OrigChars 和 EncrChars) char temporary_
Qt 版本 5.01 平台 windows 64 位 问题:错误:没有操作数“ #include #include #include namespace { std::ost
#include #include #define SIGBAD(signo) ((signo) = NSIG) int sigaddset(sigset_t *set, int signo
请看下面的代码。我正在使用 Apache Derby 作为嵌入式数据库 public List getDetails(String name) { List details =
我和我的讲师/实验室助理都被难住了。 出于某种原因,以下 HLSL 代码在输出窗口中返回: error X8000 : D3D11 Internal Compiler error : Invalid
我有一个创建时间跟踪器的 NPM 包,它使用 for in 来定位 MD 文件的标题,然后将其转换为跟踪器。目前,在 Mac 上运行它时工作正常,在 Windows 上我收到 dirname:miss
请注意这个问题是不是 this 的副本或 this ,因为其他问题没有运算符(operator) 组件,不要询问我正在询问的参数和参数的详细信息。 我将使用 vb.net 教授第一门编程类(class
输入 sudo apt autoremove 后出现此错误在终端 readlink: missing operand Try 'readlink --help' for more informatio
为什么 GCC 给我这个错误?我在这里做错了什么? temp.c: In function main: temp.c:6: error: invalid operands to binary +
我对此很陌生,我正在尝试将值从一个数组移动到另一个数组, 它假设是: vec1 = 1, 2, 3, 4, 5 vec2 = 5, 4, 3, 2, 1 但我收到一个错误:“指令操作数必须是相同的大小
我有一个 OR 表达式,它应该返回不是 NaN 的操作数: (1 || NaN) // evaluates to 1 (NaN || 1) // evaluates to 1 但是当另一个操作数也是一
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 4 年前。 Improve th
这道题是基于 Javascript 的,但适用于一般的逻辑运算 拿代码举例 if (baseText[i] == "."){ /*splice array*/;} if (baseText[
我似乎无法找到使程序运行的问题。 C 告诉我“错误:二进制操作数无效!= 'grocerylist'(又名 structgrocerylist)和 'int' 当我尝试解决此问题时,会弹出其他错误,除
我正在查看 the docs并尝试了解运算符的实际工作方式。 The increment operator (++) increments its operand by 1. The incremen
我有一个很长的 json 字符串,"attributeName":"Loc ID"},"operands":["10000"]}],"Frequency":{"type":" 这个只是其中的一部分,我
目前,我尝试编译 OpenVDB,它依赖于 Threading Building Blocks。我收到以下错误: In file included from /usr/include/tbb/enum
我收到的错误: /usr/include/c++/7/bits/stl_function.h:386: error: no operator " NearestNeighbor::nearest_pa
我有一个类Color , 那有 friend std::ostream& operator void print_head(const T& head, sost& o) { o (rsym,
我是一名优秀的程序员,十分优秀!