#B4211. [常州市程序设计小能手 2022] 可能的三角形

    ID: 9431 远端评测题 1000ms 512MiB 尝试: 0 已通过: 0 难度: 3 上传者: 标签>数学2022江苏分支结构分类讨论小学科创活动

[常州市程序设计小能手 2022] 可能的三角形

题目背景

搬运自 http://czoj.com.cn/p/452。数据为民间数据。

题目描述

X\text{X} 和小 Y\text Y 都是龙城学堂的资深学员,为了丰富学弟学妹们的课余生活,小 X\text{X} 和小 Y\text{Y} 发明了一个简单的数字游戏。

Y\text{Y} 有三个正整数 A,B,C(2ABC)A,B,C(2≤A≤B≤C),且 A,B,CA,B,C 刚好构成一个三角形的三条边。这些数字是保密的,他不会直接透露给小 X\text{X}。他会告诉小 X\text{X} 一共 44 个正整数 x1,x2,x3,x4x_1,x_2,x_3,x_4,并宣称 x1,x2,x3,x4x_1,x_2,x_3,x_4 每个数必定是 A,B,C,A+B,A+C,B+CA,B,C,A+B,A+C,B+CA+B+CA+B+C 之一。

为了公平起见,小 Y\text{Y} 不可能撒谎,也就是说他给出的这些正整数里一定存在至少一组对应的合法的 (A,B,C)(A,B,C),满足 A,B,CA,B,C 恰好是某个三角形的三条边。

X\text{X} 百思不得其解,所以请你来求出有哪些三元组 (A,B,C)(A,B,C) 符合条件。

输入格式

一行四个用空格隔开的正整数 x1,x2,x3,x4x_1,x_2,x_3,x_4

输出格式

输出若干行,每行三个整数,两数之间严格用一个空格隔开,表示一组可能的 (A,B,C)(A,B,C),使得 A,B,CA,B,C 恰好是某个三角形的三条边。输出时要求按照 AA 升序输出,如果 AA 相同则按照 BB 升序输出,如果 A,BA,B 都相同则按照 CC 升序输出。所谓升序是指从小到大的次序,输入数据保证至少有一组解。

2 4 5 7
2 2 3
2 3 4
2 4 5

提示

样例解释

对于第一组解,A=2,B=2,C=3A=2,B=2,C=3,输入的 44 个数对应的值分别是 A,A+B,A+C,A+B+CA,A+B,A+C,A+B+C

对于第二组解,A=2,B=3,C=4A=2,B=3,C=4,输入的 44 个数对应的值分别是 A,C,A+B,B+CA,C,A+B,B+C

对于第三组解,A=2,B=4,C=5A=2,B=4,C=5,输入的 44 个数对应的值分别是 A,B,C,A+CA,B,C,A+C

除此之外不可能存在其它符合条件的三角形了。注意 (1,2,4)(1,2,4) 不可能组成三角形。

数据规模与约定

对于所有数据,1x1,x2,x3,x41091≤x_1,x_2,x_3,x_4≤10^9。 | 测试点编号 | 特殊性质 | | :----------: | :----------: | | 11 | 保证答案的 A,B,CA,B,C 构成直角三角形 | | 22 | 保证答案的 A,B,CA,B,C 构成等腰三角形 | | 33 | 保证答案的 A,B,CA,B,C 构成等边三角形 | | 161 \sim 6 | 保证答案的 A,B,CA,B,C 唯一 | | 7107 \sim 10 | 1x1,x2,x3,x41001≤x_1,x_2,x_3,x_4≤100 | | 112011 \sim 20 | 无 |