首页 > 试题广场 >

比较x和y的大小: 【单选】 #include io

[单选题]
下面代码说法正确的是()
#include <iostream>
using namespace std;
int main(){
    int x = -1;
    unsigned int y = 2;

    if(x > y) {
        cout << "x is greater";
    } else {
        cout << "y is greater";
    }
}


  • x is greater
  • y is greater
  • 依赖实现
  • 随机
有符号数与无符号数比较,会自动转换为无符号数,-1补码最高那位是1,比2大太多了
发表于 2020-08-21 17:26:57 回复(3)
cout<<(1>-2)<<endl;                      // 1 正常,都是有符号数
 cout<<((unsigned int)1>-2)<<endl;  // 0 -2被转换为无符号数.
 cout<<((unsigned

这个问题测试是否懂得C语言中的整数自动转换原则,有些开发者懂得极少这些东西。当表达式中存在有符号类型和无符号类型时所有的操作数都自动转换为无符号类型。因此,从这个意义上讲,无符号数的运算优先级要高于有符号数,这一点对于应当频繁用到无符号数据类型的嵌入式系统来说是丰常重要的。
首先进行一个实验,分别定义一个signed int型数据和unsigned int型数据,然后进行大小比较:
    unsigned int a=20;
    signed int b=-130;
a>b?还是b>a?实验证明b>a,也就是说-130>20,为什么会出现这样的结果呢?
这是因为在C语言操作中,如果遇到无符号数与有符号数之间的操作,编译器会自动转化为无符号数来进行处理,因此a=20,b=4294967166,这样比较下去当然b>a了。
再举一个例子:
 unsigned int a=20;
 signed int b=-130;
 std::cout<<a+b<<std::endl;
结果输出为4294967186,同样的道理,在运算之前,a=20,b被转化为4294967166,所以a+b=4294967186

减法和乘法的运算结果类似。
如果作为signed int型数据的b=-130,b与立即数之间操作时不影响b的类型,运算结果仍然为signed int型:
signed int b=-130;
std::cout<<b+30<<std::endl;
输出为-100。
而对于浮点数来说,浮点数(float,double)实际上都是有符号数,unsigned 和signed前缀不能加在float和double之上,当然就不存在有符号数根无符号数之间转化的问题了。

int)1>-2.)<<endl; // 1 float不存在无符号数,所以,无符号数肯定大于float型的负数!
发表于 2020-08-15 11:59:42 回复(0)
有符号数和无符号数比较大小,要先把有符号数转化为无符号数,再进行比较。
发表于 2020-08-04 14:36:49 回复(0)
发表于 2020-08-12 14:43:41 回复(0)
有符号数与无符号数比较,会自动转换为无符号数据-1补码最高位是1,比2大太多了
发表于 2022-02-18 15:33:40 回复(1)

根据给定代码,x被初始化为-1,y被初始化为2。在if语句中,比较x和y的大小。

由于x是一个有符号整数(int),而y是一个无符号整数(unsigned int),在进行比较时会发生整数类型的升级。

升级后,x被转换为无符号整数,并且新的值为4294967295(如果使用32位系统)。然后,比较4294967295(即x)和2(即y)。

发表于 2023-09-25 21:10:42 回复(0)
signned int 与 unsihned int 比较,有符号叔转化为无符号数
发表于 2022-08-30 21:52:33 回复(0)
有符号数和无符号数比较大小,要先把有符号数识别为无符号数,再进行比较。本质上在内存中数据无变化 。
发表于 2022-07-08 08:10:34 回复(0)
发表于 2022-03-27 10:12:22 回复(0)