学不死就死里xue 发表于 2023-7-2 17:00:32

为什么是余一呢

int main()
{
        double a=28;
        int b;
        b=(int)a%9%4;
        printf("%d",b);
       

        return 0;
}

isdkz 发表于 2023-7-2 17:01:09

在这段代码中,变量a的值是28,变量b是整型。

首先,将变量a转换为整型,即将28转换为整型,得到28。

然后,对28进行求余运算,即28%9,结果是1。这是因为28除以9等于3,余数是1。

接下来,对1进行求余运算,即1%4,结果是1。因为1除以4等于0,余数是1。

最后,将变量b的值1打印出来。

所以,程序的输出结果是1。

sfqxx 发表于 2023-7-2 17:19:44

本帖最后由 sfqxx 于 2023-7-2 17:22 编辑

在这段代码中,首先将浮点数28赋值给double类型的变量a。然后,通过进行取余运算符(%)计算a对9取余的结果,并将结果转换为int类型,再对这个结果对4取余。

最后,将b的值打印出来。

根据C语言中的操作符优先级,取余运算符(%)的优先级高于赋值运算符(=)。因此,代码中的表达式`b=(int)a%9%4`实际上等价于`(b=(int)a%9)%4`。

现在我们来逐步分析这个表达式的计算过程:

1. 将a强制转换为int类型,得到28。

2. 对28对9取余,结果为1。

3. 将1对4取余,结果为1。

4. 最后将b的值设为1。

所以,根据给定的代码,b的值会是1,也就是余1。

求最佳答案{:10_254:}

陶远航 发表于 2023-7-2 20:26:55

您的代码中进行了一系列的取模运算,最后输出了变量b的值。

首先,将double类型的变量a赋值为28,然后进行以下运算:

    a%9:将28除以9,并取余数,结果为1。
    1%4:将1除以4,并取余数,结果为1。

最后,将结果1赋值给整型变量b,并使用printf函数输出b的值,结果为1。

所以,根据您提供的代码和运算过程,最终输出的结果是1。

zhangjinxuan 发表于 2023-7-2 21:44:37

请注意,取模运算的运算顺序仍然是从左至右

编程追风梦 发表于 2023-7-3 10:26:00




在给定的代码中,我们可以看到以下行:

b = (int)a % 9 % 4;



这里发生了一系列运算。首先,将变量 `a` 的值转换为整数,因为 `a` 的类型是 `double`,通过 `(int)a` 将其转换为整数 `28`。

然后,对 `28` 进行取模运算 `% 9`,结果是 `1`。这是因为 `28` 除以 `9` 的商为 `3`,余数为 `1`。

最后,对 `1` 进行取模运算 `% 4`,结果仍然是 `1`。这是因为 `1` 除以 `4` 的商为 `0`,余数为 `1`。

因此,最终的结果是 `1`。

换句话说,代码中的 `b=(int)a%9%4` 实际上计算了 `28` 除以 `9` 的余数,然后再对该余数进行 `4` 的取模运算,最终得到的结果是 `1`。


如果结果有帮助,给个最佳答案吧,求求了

python/print 发表于 2023-7-5 19:28:03

本帖最后由 python/print 于 2023-7-6 11:39 编辑

(首先了解:余数是什么,百分号是求余的意思)
*a 是 28,下文28代替a
28 /(除以) 9 = 3 ……(余) 1
1 /(除以) 4 = 0 ……(余) 1   

到这里,答案为什么是一大家肯定都知道了

求最佳答案{:5_111:}

沐雨尘枫 发表于 2023-7-8 19:59:20

根据代码的运算过程,结果为 b = 2。因为 (int)a 的值是 28,28 除以 9 的余数是 1,1 再除以 4 的余数是 1,所以最终 b 的值为 1。

沐雨尘枫 发表于 2023-7-8 19:59:54

如有帮助求最佳答案

gogo57913 发表于 2023-7-9 02:07:20

一个数除以另一个数,要是比另一个数小的话,商为0,余数就是它自己。例如:1除以2,商数为0,余数为1。2除以3,商数为0,余数为2。
页: [1]
查看完整版本: 为什么是余一呢