題目描述
歐幾里德的兩個後代stan和ollie正在玩一種數字遊戲,這個遊戲是他們的祖先歐幾里德發明的。給定兩個正整數m和n,從stan開始,從其中較大的乙個數,減去較小的數的正整數倍,當然,得到的數不能小於0。然後是ollie,對剛才得到的數,和m,n中較小的那個數,再進行同樣的操作……直到乙個人得到了0,他就取得了勝利。下面是他們用(25,7)兩個數遊戲的過程:
start:25 7
stan:11 7
ollie:4 7
stan:4 3
ollie:1 3
stan:1 0
stan贏得了遊戲的勝利。 現在,假設他們完美地操作,誰會取得勝利呢?
輸入輸出格式
輸入格式:
第一行為測試資料的組數c。下面有c行,每行為一組資料,包含兩個正整數m, n。(m, n不超過長整型。)
輸出格式:
對每組輸入資料輸出一行,如果stan勝利,則輸出「stan wins」;否則輸出「ollie wins」
輸入輸出樣例
輸入樣例#1:
2 25 7
24 15
輸出樣例#1:
stan wins
ollie wins
#include
#include
int tot,m,n;
int main()
int f=1;
while ((m/n==1)and(m%n!=0))
if (f==1) printf("stan wins\n");
else
printf("ollie wins\n");
}return
0;}
洛谷P1290 歐幾里德的遊戲
歐幾里德的兩個後代stan和ollie正在玩一種數字遊戲,這個遊戲是他們的祖先歐幾里德發明的。給定兩個正整數m和n,從stan開始,從其中較大的乙個數,減去較小的數的正整數倍,當然,得到的數不能小於0。然後是ollie,對剛才得到的數,和m,n中較小的那個數,再進行同樣的操作 直到乙個人得到了0,他...
洛谷P1290 歐幾里德的遊戲
題目 只要出現n 2 m,就可以每次把較大的數控制在較小的數的一倍與二倍之間,則控制了對方的走法 每次取後兩個數大小交換,這時可能出現整除,而上述方法可以保證每次可能出現整除時都輪到自己,所以必勝。如下 include include using namespace std typedef long...
洛谷1290 歐幾里德的遊戲(博弈論)
點此看題面 大致題意 給定兩個正整數,從sta nstan stan 開始,每次將兩個數中較大的數減去較小數的正整數倍 得到數不能小於0 然後是oll ie ollie olli e進行同樣操作。若誰先得到0誰就勝利,請你求出誰會取得勝利。分類討論 這一看就是博弈論題。我們可以用w x y w x,...