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 倍。請你指出誰比你強應 從之 誰比你弱應 改之 輸入格式 輸...