DOTCPP题目 2782: 整数大小比较

一、题目

题目描述

输入两个整数,比较它们的大小。

输入格式

一行,包含两个整数x和y,中间用单个空格隔开。

0 <= x < 2^32, -2^31 <= y < 2^31。

输出格式

一个字符。

若x > y,输出 > ;

若x = y,输出 = ;

若x < y,输出 < 。

样例输入

复制

1000 100

样例输出

复制

>

二、分析


0 <= x < 2^32, -2^31 <= y < 2^31,x是无符号数,而当y<0时是有符号数,考虑这种特殊情况,有符号数会转化成比无符号数还大的数,导致结果错误。例如:x=4294967242,y=-1,程序会输出<。

三、代码

cpp 复制代码
#include<stdio.h>

int main()
{
	/*C语言
	当有符号数n(-2^31~2^31-1)和无符号数据m(0~2^32-1)进行比较时,
	会进行将有符号的数据转化为无符号的数据,
	而且这种转换会使有符号的被转换成大于无符号的一个最大的值
	所以,当m是无符号数时,n<0,n作为有符号数,n会被转换,
	所以要输出>号 
	*/	 
	int n;
	unsigned int m; 
	scanf("%d %d",&m,&n);
	if(m>n || n<0){ //n<0时,作为有符号数 
		printf(">");
	} else if(m==n){
		printf("=");
	}else{
		printf("<");
	}
	return 0;	
 } 
相关推荐
楼田莉子13 分钟前
C++学习之STL学习:string类常用接口的模拟实现
开发语言·数据结构·c++·学习·算法·stl
勇闯逆流河14 分钟前
【数据结构】链式二叉树
数据结构·算法
记得早睡~35 分钟前
leetcode3-无重复字符的最长子串
javascript·数据结构·算法·leetcode
鲨鱼吃橘子1 小时前
HTTPS协议原理
网络·c++·网络协议·算法·http·https
竹下为生1 小时前
LeetCode --- 450周赛
算法·leetcode·职场和发展
路人与大师2 小时前
用算法实现 用统计的方式实现 用自然语言处理的方法实现 用大模型实现 专利精益化统计分析
人工智能·算法·自然语言处理
五点钟科技2 小时前
大语言模型的完整训练周期从0到1的体系化拆解
算法·自然语言处理
Dxy12393102162 小时前
Python经典算法实战
开发语言·python·算法
五步晦暝2 小时前
【排序算法】典型排序算法 Java实现
java·算法·排序算法
小猿_005 小时前
C语言指针进阶
c语言·数据结构·算法