首页 > 其他 > 详细

1065 A+B and C (64bit) (20 分)

时间:2021-07-22 23:53:07      阅读:43      评论:0      收藏:0      [点我收藏+]

1065 A+B and C (64bit) (20 分)

Given three integers A, B and C in [?263,263], you are supposed to tell whether A+B>C.

Input Specification:

The first line of the input gives the positive number of test cases, T (≤10). Then T test cases follow, each consists of a single line containing three integers A, B and C, separated by single spaces.

Output Specification:

For each test case, output in one line Case #X: true if A+B>C, or Case #X: false otherwise, where X is the case number (starting from 1).

Sample Input:

3
1 2 3
2 3 4
9223372036854775807 -9223372036854775808 0

Sample Output:

Case #1: false
Case #2: true
Case #3: false

思路

? 由于long long的范围是[-263, 263),因此题目中给出的两个整数相加有可能会溢出(正溢出或负溢出),直接进行大小判断会造成错误。在计算机组成原理中会指出,如果两个正数之和等于负数或是两个负数之和等于正数,那么就是溢出。

对于溢出后的具体范围,可以进行如下分析:
①当A+B≥2^63时,显然有A+B>C成立,但A+ B会因超过long long的正向最大值而发生正溢出。由于题目给定的A和B最大均为263-1,故A+B最大为264-2,因此使用long long存储正溢出后的值的区间为[-263, -2] (由(264 - 2)%(264)= -2可得右边界)。所以,当A>0,B>0,A+B<0时为正溢出,输出true。
②当A+B<-263时,显然有A+B<C成立,但A+ B会因超过long long的负向最小值而发生负溢出。由于题目给定的A和B最小均为263,故A+ B最小为264,因此使用longlong存储负溢出后的值的区间为[0, 263) (由( -264)%264=0可得左边界)。所以,当A<0,B<0,A+ B≥0时为负溢出,输出false.
③在没有溢出的情况下,当A+B>C时,输出true; 当A+B≤C时,输出false.

  • 注意点
    ①经测试,数据中并没有A或B取到263的情况,因此题目中的数据范围可能是写错了,应该是[- 263, 263)才更符合数据,否则就要用带负数的大整数运算了(因为long long 存储263时会自动变成- 263,无法区分左右边界)。
    ②A+ B必须存放到long long型变量中才可与C进行比较,而不可以在if的条件中直
    接相加与C比较,否则会造成后两组数据错误。

参考代码

  • 1号:注意long long类型的变量,要用%lld
#include<stdio.h>
int main(){
	int t;
	scanf("%d", &t);
	long long a[10], b[10], c[10];
	for(int i = 0; i < t; i++){
		scanf("%lld %lld %lld", &a[i], &b[i], &c[i]);
		}
	for(int i = 0; i < t; i++){
		long long sum;
		sum = a[i] + b[i];
		if(a[i] > 0 && b[i] > 0 && sum < 0) printf("Case #%d: true\n", i + 1);
		else if(a[i] < 0 && b[i] < 0 && sum >= 0) printf("Case #%d: false\n", i+1);
		else if(sum > c[i])	printf("Case #%d: true\n", i + 1);
		else printf("Case #%d: false\n", i + 1);
	}	
	return 0;
}
  • 2号:更加简单,其实不需要用数组,在循环的时候就有i可以引用

    #include <cstdio>
    using namespace std;
    int main() {
    	int n;
         scanf("%d", &n);
         for(int i = 0; i < n; i++) {
         	long long a, b, c;
         	scanf("%lld %lld %lld", &a, &b, &c);
         	long long sum = a + b;
    	 	if(a > 0 && b > 0 && sum < 0) {
         		printf("Case #%d: true\n", i + 1);
         	} else if(a < 0 && b < 0 && sum >= 0){
         		printf("Case #%d: false\n", i + 1);
        	} else if(sum > c) {
         		printf("Case #%d: true\n", i + 1);
         	} else {
         		printf("Case #%d: false\n", i + 1);
         	}
         }
         return 0;
    }
    

1065 A+B and C (64bit) (20 分)

原文:https://www.cnblogs.com/shiff/p/15046881.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!