子曰:「三人行,必有我師焉。擇其善者而從之,其不善者而改之。」又是一道數學題。本題給定甲、乙、丙三個人的能力值關係為:甲的能力值確定是 2 位正整數;把甲的能力值的 2 個數字調換位置就是乙的能力值;甲乙兩人能力差是丙的能力值的 x 倍;乙的能力值是丙的 y 倍。請你指出誰比你強應「從之」,誰比你弱應「改之」。
輸入格式:
輸入在一行中給出三個數,依次為:m(你自己的能力值)、x 和 y。三個數字均為不超過 1000 的正整數。
輸出格式:
在一行中首先輸出甲的能力值,隨後依次輸出甲、乙、丙三人與你的關係:如果其比你強,輸出 cong;平等則輸出 ping;比你弱則輸出 gai。其間以 1 個空格分隔,行首尾不得有多餘空格。
注意:如果解不唯一,則以甲的最大解為準進行判斷;如果解不存在,則輸出 no solution。
輸入樣例 1:
48 3 7
輸出樣例 1:
48 ping cong gai
輸入樣例 2:
48 11 6
輸出樣例 2:
no solution
記甲、乙、丙分別為a、b、c,甲的兩位數字為i、j,則可得:
a = 10i + j
b = 10j + i
|a - b| = 9 |(i-j)| = xc
b = 10j + i = yc
聯立3、4得:
i = j時,無解;
i > j時,(9y-x)i = (9y+10x)j
i < j時,(9y+x)i = (9y-10x)j
在[10, 99]中遍歷i、j的值,分情況計算即可。
從99~10倒序遍歷,找到的第乙個值即為最大結果。注意跳出2重迴圈需要用乙個flag控制。
參觀了柳神的**:pat 1088
三人行(20 分)- 乙級_柳婼 の blog-csdn部落格
發現自己搞複雜了,涉及到求絕對值時可以不必分情況討論,直接用abs()
即可。
#include
#include
using
namespace std;
intmain()
else
if(i>j)
else
if(iif(t1==t2)}if
(isend)}if
(a[0]==
0)else
else
if(m>a[i]
)else}}
cout << endl;
return0;
}
PAT 乙級 1088 三人行
子曰 三人行,必有我師焉。擇其善者而從之,其不善者而改之。本題給定甲 乙 丙三個人的能力值關係為 甲的能力值確定是 2 位正整數 把甲的能力值的 2 個數字調換位置就是乙的能力值 甲乙兩人能力差是丙的能力值的 x 倍 乙的能力值是丙的 y 倍。請你指出誰比你強應 從之 誰比你弱應 改之 輸入格式 輸...
PAT乙級1088 三人行 邏輯題
子曰 三人行,必有我師焉。擇其善者而從之,其不善者而改之。本題給定甲 乙 丙三個人的能力值關係為 甲的能力值確定是 2 位正整數 把甲的能力值的 2 個數字調換位置就是乙的能力值 甲乙兩人能力差是丙的能力值的 x 倍 乙的能力值是丙的 y 倍。請你指出誰比你強應 從之 誰比你弱應 改之 輸入格式 輸...
PAT乙級1088 三人行 Cpp
子曰 三人行,必有我師焉。擇其善者而從之,其不善者而改之。本題給定甲 乙 丙三個人的能力值關係為 甲的能力值確定是 2 位正整數 把甲的能力值的 2 個數字調換位置就是乙的能力值 甲乙兩人能力差是丙的能力值的 x 倍 乙的能力值是丙的 y 倍。請你指出誰比你強應 從之 誰比你弱應 改之 輸入在一行中...