TIOJ 1790 好激烈

Description

「嗚,不可能,這不可能塞得進去!!! 啊~~~」妤嬌姊姊道。

為了前往外太空解救妁艷,妤嬌決定前往歐洲尋找最先進的航太科技。這個國家是位在白俄羅斯和波蘭的邊境的一個小王國。啵啵啪啪王國,一個世襲君主國家,國民血統為純正的 1/2 白俄羅斯 + 1/2 波蘭的完美比例組成。國民擁有驚人的平均 514 的智商,能發展出遠遠超越 SERN 的核物裡和遠遠超越地球聯合、吉翁、紮夫特的航太科技,並不意外。身為潮能力者,LEVEL-5,像是穿越電腦螢幕網路王國傳送 (Network Transfer to Realms, NTR) 這種事情妤嬌當然做過很多次。

「啊~ 好激烈,妤嬌,姊姊快不行了~ 在這樣下去姊姊會~~ 姊姊會壞掉~~」
「姊姊,我也…我也快不行了~~~」

由於妤嬌隨身攜帶的 laptop 螢幕太小了,要把人塞進去有點困難。妤嬌研判,照這樣的情況下去,再把兩個人 (妤嬌自己則可以穿越隧道過去) 都傳送過去之前電腦螢幕有可能會壞掉!

妤嬌說:「沒辦法,妳們兩個一起來吧!」
「嗚!! 兩邊!? 兩邊一起絕對不行的!!」兩位美少女同聲道。
(十分鐘過後)
「啊~ 妤嬌~~」
「妤嬌葛格~~ 啊~~」
三人都因為使力而身體微微泛紅,身上沾著彼此的汗珠。
「要去了!!!!!!」妤嬌喘著氣大喊。
「在裡面!?!?!?!?」
「妤嬌!!!!~~~~~~~~~」

周圍閃了幾下白光,費盡工夫,總算把兩人塞進螢幕裡面了。剩下的工作就有開啓「人工少女 3」把電腦中的兩人送到啵啵啪啪王國了。

「要產品序號!?」

點開遊戲後才發現事情不妙!
在妤嬌的記憶中,序號是由下列方法所生成的:
給定質數 p 和正整數 b,c,n,定義序列 {a0=1,ai(ai+1c)=b,for i=0,1, 序號為最小的正整數 m,使得 p|man1。由於妤嬌是個天才,你只需要幫他驗算就可以了,輸出序號 modq

Input Format

第一行有五個正整數 b,c,n,p,q,其中 p,q 為質數,意義如上文所述。
對於 30% 的測資 n,p1000
對於 60% 的測資 n,p106
對於 100% 的測資 b,c,n,p,q2×109gcd(b,c)=1

Output Format

輸出一個正整數 mmodq,意義如上文所述。若此正整數 m 不存在,輸出 1
但是聰明的你知道,puts("-1");並不會拿到任何分數,因為你很想玩人工少女 3。

Sample Input

3 4 2 5 7

Sample Output

0

Solution

ai=αiβi,其中 αi,βiZ1gcd(αi,βi)=1。由 ai(ai+1c)=b,可知 αi+1βi+1=bβi+cαiαi. 假定某個 i 滿足 gcd(αi,b)=1,則顯然我們有
  1. gcd(bβi+cαi,αi)=gcd(bβi,αi)=1
  2. gcd(bβi+cαi,b)=gcd(cαi,b)=1
注意這樣一來
  1. αi+1=bβi+cαi
  2. βi+1=αi
  3. gcd(αi+1,b)=1
因為 α0=β0=1gcd(α0,b)=1,我們得到 (αnβn)=(cb10)n(11).m=βnx,其中 xZ1。我們希望找到最小的 x 使得 man=αnx1 (modp),而這只要找到 αnZp 裡的乘法反元素就行了。

我的 code:
https://ideone.com/PIv8N5

留言

這個網誌中的熱門文章

2020 全國賽驗題心得

水母上 Divide-and-Conquer

109 學年度全國資訊學科能力競賽各題詳解