鱼C论坛

 找回密码
 立即注册
查看: 4540|回复: 7

输入8个10进制整数,依次输出每一个数的八进制和十六进制表示

[复制链接]
发表于 2019-3-12 17:09:18 | 显示全部楼层 |阅读模式

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

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

x
#include<stdio.h>
int main()
{
        int a,b,c,d,e,f,g,h;
        scanf("%d",&a);
        scanf("%d",&b);
        scanf("%d",&c);
        scanf("%d",&d);
        scanf("%d",&e);
        scanf("%d",&f);
        scanf("%d",&g);
        scanf("%d",&h);
       
        printf("%o %x\n",a,a);
        printf("%o %x\n",b,b);
        printf("%o %x\n",c,c);
        printf("%o %x\n",d,d);
        printf("%o %x\n",e,e);
        printf("%o %x\n",f,f);
        printf("%o %x\n",g,g);
        printf("%o %x\n",h,h);
       
        return 0;
}
为什么为负数时出错
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-3-12 18:35:08 | 显示全部楼层
本帖最后由 jackz007 于 2019-3-12 18:39 编辑

      负数的时候没有出错,下面解释一下。

      32 位数对数字的表达空间是 0x00000000 ~ 0xffffffff(0 ~ 4294967295),对于整形数而言,这个空间被一分为二,其中,0x00000000 ~ 0x7ffffffff(0 ~ 2147483647) 用于表达正整数;0x80000000 ~ 0xffffffff(-2147483648 ~ -1)用于表达负整数,所以,如果用十六进制数来表示  -1 就是 0xffffffff,-2 为 0xfffffffe,-3 为 0xfffffffd . . . . . .  -2147483648 为 0x80000000。

      这个问题可以通过下面的代码加深理解:
  1. #include <stdio.h>
  2. main(void)
  3. {
  4.     int a , b                           ;
  5.     a = 0x7fffffff                      ;
  6.     b = a + 1                           ;
  7.     printf("a = %d , b = %d\n" , a , b) ;
  8. }
复制代码

    这个代码将会分别输出32位正、负整数中绝对值最大的极限值。是不是很神奇?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-3-12 19:03:40 | 显示全部楼层
jackz007 发表于 2019-3-12 18:35
负数的时候没有出错,下面解释一下。

      32 位数对数字的表达空间是 0x00000000 ~ 0xffffffff ...

请问要怎么解决
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-12 19:49:15 | 显示全部楼层
本帖最后由 jackz007 于 2019-3-12 19:51 编辑


    这是约定,只要遵守就好了。楼主想要解决什么?难道你想看到负的十六进制和八进制数?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-3-12 20:45:13 | 显示全部楼层
jackz007 发表于 2019-3-12 19:49
这是约定,只要遵守就好了。楼主想要解决什么?难道你想看到负的十六进制和八进制数?

是的
求帮忙
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-12 22:28:41 | 显示全部楼层
     十六进制和八进制数没有正负数之分,这里违心帮你一把,可别说代码是我写的,会让真正的程序员鄙视的!
  1. #include<stdio.h>
  2. int main()
  3. {
  4.         int a , b ,c , d , e , f , g , h         ;
  5.         scanf("%d" , & a)                        ;
  6.         scanf("%d" , & b)                        ;
  7.         scanf("%d" , & c)                        ;
  8.         scanf("%d" , & d)                        ;
  9.         scanf("%d" , & e)                        ;
  10.         scanf("%d" , & f)                        ;
  11.         scanf("%d" , & g)                        ;
  12.         scanf("%d" , & h)                        ;
  13.         if (a >= 0) printf("0%o 0x%x\n" , a , a) ;
  14.         else printf("-0%o -0x%x\n" , -a , -a)    ;
  15.         if (b >= 0) printf("0%o 0x%x\n" , b , b) ;
  16.         else printf("-0%o -0x%x\n" , -b , -b)    ;
  17.         if (c >= 0) printf("0%o 0x%x\n" , c , c) ;
  18.         else printf("-0%o -0x%x\n" , -c , -c)    ;
  19.         if (d >= 0) printf("0%o 0x%x\n" , d , d) ;
  20.         else printf("-0%o -0x%x\n" , -d , -d)    ;
  21.         if (e >= 0) printf("0%o 0x%x\n" , e , e) ;
  22.         else printf("-0%o -0x%x\n" , -e , -e)    ;
  23.         if (f >= 0) printf("0%o 0x%x\n" , f , f) ;
  24.         else printf("-0%o -0x%x\n" , -f , -f)    ;
  25.         if (g >= 0) printf("0%o 0x%x\n" , g , g) ;
  26.         else printf("-0%o -0x%x\n" , -g , -g)    ;
  27.         if (h >= 0) printf("0%o 0x%x\n" , h , h) ;
  28.         else printf("-0%o -0x%x\n" , -h , -h)    ;
  29. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-3-13 12:35:06 | 显示全部楼层
jackz007 发表于 2019-3-12 22:28
十六进制和八进制数没有正负数之分,这里违心帮你一把,可别说代码是我写的,会让真正的程序员鄙视的 ...

谢谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-3-17 21:22:18 | 显示全部楼层

      如果问题已经解决,麻烦你终结求助状态好吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-2 14:48

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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