2017.07.15【NOIP提高組】模擬賽B組 不等式(solve) 題解

原題:

http://172.16.0.132/senior/#contest/show/2061/2

題目描述:

小z熱衷于數(shù)學(xué)怠李。
今天數(shù)學(xué)課的內(nèi)容是解不等式:L<=Sx<=R捺癞。小z心想這也太簡(jiǎn)單了髓介,不禁陷入了深深的思考:假如已知L箱歧、R叫胁、S微谓、M仲智,滿足L<=(Sx)mod M<=R的最小正整數(shù)x該怎么求呢钓辆?

輸入:

第一行包含一個(gè)整數(shù)T功戚,表示數(shù)據(jù)組數(shù),接下來(lái)是T行乘粒,每行為四個(gè)正整數(shù)M、S、L他爸、R。

輸出:

對(duì)于每組數(shù)據(jù)讨跟,輸出滿足要求的x值,若不存在,輸出-1澜共。

樣例輸入:

1
5 4 2 3

樣例輸出:

2

數(shù)據(jù)范圍限制:

30%的數(shù)據(jù)中保證有解并且答案小于等于10^6瘦黑;
另外20%的數(shù)據(jù)中保證L=R;
100%的數(shù)據(jù)中T<=100,M冗栗、S葛虐、L涕蚤、R<=10^9西疤。

分析:

對(duì)于的做法扰她,首先我們排除特殊情況芭碍,不妨設(shè),0<=l<=r,0<=s<=m徒役。
顯然若存在一個(gè)的倍數(shù)滿足l<=sx<=r,那么此時(shí)的答案就是x窖壕。
若不存在忧勿,我們不妨將約束式改寫成代數(shù)式l<=s
x-my<=r。進(jìn)一步改寫成以為y主元瞻讽,即-r<=my-sx<=-l狐蜕,再把它還原為取模的形式:(-r mod s)<=my mod s<=(-l mod s)。若能求出最小的滿足上式的y值卸夕,則可以求出唯一滿足上式的x值(因?yàn)閰^(qū)間中沒有s的倍數(shù))。
所以我們只需要將讀入的四個(gè)數(shù)標(biāo)準(zhǔn)化婆瓜,判斷是否存在簡(jiǎn)單解以及判斷無(wú)解快集,假如需要的話遞歸調(diào)用函數(shù)贡羔,直至問題解決。

實(shí)現(xiàn):

#include<cstdio>

long long t,m,s,l,r;
long long dg(long long m,long long s,long long l,long long r)
{
    if(l==0) return 0;
    if(l>=m || l>r || s%m==0) return -1;
    s%=m;
    long long x=(l-1)/s+1;
    if(x*s<=r) return x;
    long long y=dg(s,m,(-r%s+s)%s,(-l%s+s)%s);
    if(y==-1) return y;
    x=(r+m*y)/s;
    if(s*x-m*y>=l) return (x%m+m)%m;
    return -1;
}
int main()
{
    freopen("solve.in","r",stdin);freopen("solve.out","w",stdout);
    scanf("%lld",&t);
    while(t--)
    {
        scanf("%lld%lld%lld%lld",&m,&s,&l,&r);
        if(r>=m) r=m-1;
        printf("%lld\n",dg(m,s,l,r));
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末个初,一起剝皮案震驚了整個(gè)濱河市乖寒,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌院溺,老刑警劉巖楣嘁,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異珍逸,居然都是意外死亡逐虚,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門谆膳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)叭爱,“玉大人,你說我怎么就攤上這事漱病÷蛭恚” “怎么了?”我有些...
    開封第一講書人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵杨帽,是天一觀的道長(zhǎng)漓穿。 經(jīng)常有香客問我,道長(zhǎng)注盈,這世上最難降的妖魔是什么晃危? 我笑而不...
    開封第一講書人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮当凡,結(jié)果婚禮上山害,老公的妹妹穿的比我還像新娘。我一直安慰自己沿量,他們只是感情好浪慌,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著朴则,像睡著了一般权纤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上乌妒,一...
    開封第一講書人閱讀 50,084評(píng)論 1 291
  • 那天汹想,我揣著相機(jī)與錄音,去河邊找鬼撤蚊。 笑死古掏,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的侦啸。 我是一名探鬼主播槽唾,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼丧枪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了庞萍?” 一聲冷哼從身側(cè)響起拧烦,我...
    開封第一講書人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎钝计,沒想到半個(gè)月后恋博,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡私恬,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年债沮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片践付。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡秦士,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出永高,到底是詐尸還是另有隱情隧土,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布命爬,位于F島的核電站曹傀,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏饲宛。R本人自食惡果不足惜皆愉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望艇抠。 院中可真熱鬧幕庐,春花似錦、人聲如沸家淤。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)絮重。三九已至冤寿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間青伤,已是汗流浹背督怜。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留狠角,地道東北人号杠。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像丰歌,于是被迫代替她去往敵國(guó)和親究流。 傳聞我的和親對(duì)象是個(gè)殘疾皇子辣吃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容