PAT乙級真題 1088 三人行 C 實現

2021-10-02 05:00:56 字數 1330 閱讀 9186

子曰:「三人行,必有我師焉。擇其善者而從之,其不善者而改之。」

本題給定甲、乙、丙三個人的能力值關係為:甲的能力值確定是 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 倍。請你指出誰比你強應 從之 誰比你弱應 改之 輸入在一行中...