鱼C论坛

 找回密码
 立即注册
查看: 3468|回复: 3

[已解决](-i)/j得不到想要的结果。why?

[复制链接]
发表于 2023-1-22 00:56:58 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include<stdio.h>
int main()
{
    unsigned int i , j ; /* Defined the variables as unsigned int*/
    long int k;
    printf("This program is to show the difference between (-i)/j and -(i/j) when using two positive integer variables.\n");
    printf("Please input two positive integer numbers for demonstration of the result (Separated with a comma): ");
    scanf("%u,%u", &i , &j);

    k = (-i) ;
    k /= j;
    printf("the result of (-i)/j is %d\t%d\t%d\n", (-i), j , k);
    printf("The result of -(i/j) is %d\n", -(i / j));

    return 0;
}

运行结果k /= j不对,不能理解。不希望改边i,j的unsigned定义。
最佳答案
2023-1-22 10:25:36
本帖最后由 傻眼貓咪 于 2023-1-22 10:33 编辑

不要直接写成 (-i),不要把 C 语言想成 "人类可读性语言"(我不知道这叫什么,大概是这样的意思)

unsigned i 和 j 应该写成:
(-i),正确写法应该是 -1 * (long int)i // 字面量类型需改成 long int
-(i / j),正确写法应该是 -1 * (long int)(i / j)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-1-22 10:25:36 | 显示全部楼层    本楼为最佳答案   
本帖最后由 傻眼貓咪 于 2023-1-22 10:33 编辑

不要直接写成 (-i),不要把 C 语言想成 "人类可读性语言"(我不知道这叫什么,大概是这样的意思)

unsigned i 和 j 应该写成:
(-i),正确写法应该是 -1 * (long int)i // 字面量类型需改成 long int
-(i / j),正确写法应该是 -1 * (long int)(i / j)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-1-22 14:46:49 | 显示全部楼层
题目出处:

C Programming: A Modern Approach, K. N. King, second edition, 2008  published by W. W. Norton & Company
Page 69 Exercise 4.2
中文版的题目描述是:
如果i 和 j 都是正整数, (-i)/j 的值和-(i/j)的值是否一样?请验证你的答案。


上面如果i,j,k都是int的话,运行结果没有问题。i,j改成unsigned就不行了。想不出为什么。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-5-20 11:51:19 | 显示全部楼层
在这段代码中,将无符号整数 i 和 j 定义为 unsigned int 类型,因此不能使用负数进行运算,也不能使用 %d 来打印无符号整数。同时,如果 i 的值小于 j 的值,则进行的计算会导致除以 0 的错误。

为了保持 i 和 j 的无符号定义,可以使用以下代码来替换掉原来的代码:
#include <stdio.h>

int main() {
    unsigned int i, j;
    long int k;
    printf("This program is to show the difference between (-i)/j and -(i/j) when using two positive integer variables.\n");
    printf("Please input two positive integer numbers for demonstration of the result (Separated with a comma): ");
    scanf("%u,%u", &i , &j);

    k = -((long int)i);
    k /= j;
    printf("the result of (-i)/j is %u\n", (unsigned int)k);

    printf("The result of -(i/j) is %u\n", (unsigned int)(-(i / j)));

    return 0;
}
在这里,我们将 -i 强制转换为长整型 long int,然后再取反,得到的结果存储在变量 k 中。接着,我们将 k 除以 j,并使用强制转换将 k 打印为无符号整数型 %u,最后得到的结果即为 (-i)/j 的值。

另外,在打印 (i/j) 的负数结果时,我们需要先将 i 和 j 都转换为无符号整数型,然后在计算结果的负数。这是因为如果将有符号类型的 i 和 j 直接除法,则会按照有符号类型进行提升,导致计算错误。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-12-23 22:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表