1088 三人行 20 分

2021-10-07 06:00:57 字數 1612 閱讀 2412

1088 三人行 (20 分)

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

本題給定甲、乙、丙三個人的能力值關係為:甲的能力值確定是 2 位正整數;把甲的能力值的 2 個數字調換位置就是乙的能力值;甲乙兩人能力差是丙的能力值的 x 倍;乙的能力值是丙的 y 倍。請你指出誰比你強應「從之」,誰比你弱應「改之」。

輸入在一行中給出三個數,依次為:m(你自己的能力值)、x 和 y。三個數字均為不超過 1000 的正整數。

在一行中首先輸出甲的能力值,隨後依次輸出甲、乙、丙三人與你的關係:如果其比你強,輸出cong;平等則輸出ping;比你弱則輸出gai。其間以 1 個空格分隔,行首尾不得有多餘空格。

注意:如果解不唯一,則以甲的最大解為準進行判斷;如果解不存在,則輸出no solution

48 3 7
48 ping cong gai
48 11 6
no solution
【錯誤**】

一開始自己按照邏輯來寫,很順利地直接叭叭叭地敲完了,結果發現測試點4一直沒辦法通過!!!下面附上我的錯誤**,可以看看有沒有犯同樣的錯誤。

1//1088 三人行 (20 分)

2/*3甲的能力值確定是 2 位正整數;

4把甲的能力值的 2 個數字調換位置就是乙的能力值;

5甲乙兩人能力差是丙的能力值的 x 倍;

6乙的能力值是丙的 y 倍。請你指出誰比你強應「從之」,誰比你弱應「改之」。

7*/8#include 9#include 10using namespace std;

11void print(int m, int tmp)

16int main()

31    if(i == 9)

35    cout<【正確思路 and **】

厲害的小夥伴應該已經發現了,我之前的思維陷入了乙個誤區。他很明確,甲的能力值是兩位正整數,乙的能力值是甲的兩位數倒過來,那麼說明甲和乙的能力值一定都是int型別的,但乙的不是啊!!因此,這裡需要把乙定義成double型別。

1//1088 三人行 (20 分)

2/*3甲的能力值確定是 2 位正整數;

4把甲的能力值的 2 個數字調換位置就是乙的能力值;

5甲乙兩人能力差是丙的能力值的 x 倍;

6乙的能力值是丙的 y 倍。請你指出誰比你強應「從之」,誰比你弱應「改之」。

7*/8#include 9#include 10using namespace std;

11void print(double m, double tmp)

16int main()

29    if(i == 9)

33    cout<34    print(m, jia);

35    print(m, yi);

36    print(m, bing);

37    return 0;

38}

1088 三人行 (20 分)

子曰 三人行,必有我師焉。擇其善者而從之,其不善者而改之。本題給定甲 乙 丙三個人的能力值關係為 甲的能力值確定是 2 位正整數 把甲的能力值的 2 個數字調換位置就是乙的能力值 甲乙兩人能力差是丙的能力值的 x 倍 乙的能力值是丙的 y 倍。請你指出誰比你強應 從之 誰比你弱應 改之 includ...

1088 三人行 (20 分)

單位 浙江大學 時間限制 400 ms 記憶體限制 64 mb 長度限制 16 kb 子曰 三人行,必有我師焉。擇其善者而從之,其不善者而改之。本題給定甲 乙 丙三個人的能力值關係為 甲的能力值確定是 2 位正整數 把甲的能力值的 2 個數字調換位置就是乙的能力值 甲乙兩人能力差是丙的能力值的 x ...

1088 三人行 (20 分)

子曰 三人行,必有我師焉。擇其善者而從之,其不善者而改之。本題給定甲 乙 丙三個人的能力值關係為 甲的能力值確定是 2 位正整數 把甲的能力值的 2 個數字調換位置就是乙的能力值 甲乙兩人能力差是丙的能力值的 x 倍 乙的能力值是丙的 y 倍。請你指出誰比你強應 從之 誰比你弱應 改之 輸入格式 輸...