#452. [CZOI2022 C] 可能的三角形

[CZOI2022 C] 可能的三角形

题目描述

小 X 和小 Y 都是龙城学堂的资深学员,为了丰富学弟学妹们的课余生活,小X和小Y发明了一个简单的数字游戏。小 Y 有三个正整数 A,B,C(2ABC)A,B,C(2\leq A\leq B\leq C),且 A,B,CA,B,C 刚好构成一个三角形的三条边。这些数字是保密的,他不会直接透露给小 X。他会告诉小X一共4个正整数 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 不可能撒谎,也就是说他给出的这些正整数里一定存在至少一组对应的合法的 (A,B,C)(A,B,C),满足 A,B,C A,B,C 恰好是某个三角形的三条边。 小 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,B A,B都相同则按照 CC 升序输出。所谓升序是指从小到大的次序,输入数据保证至少有一组解。

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

样例解释

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

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

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

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

数据范围

测试点编号 数据范围 特殊性质
11 1x1,x2,x3,x41001\leq x_1,x_2,x_3,x_4\leq 100 保证答案的A,B,C构成直角三角形
22 保证答案的A,B,C构成等腰三角形
33 保证答案的A,B,C构成等边三角形
464\sim 6 保证答案的A,B,C唯一
7107\sim10
112011\sim20 1x1,x2,x3,x41091\leq x_1,x_2,x_3,x_4\leq 10^9