日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

X-Magic Pair gcd,剪枝(1600)

發(fā)布時間:2025/3/19 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 X-Magic Pair gcd,剪枝(1600) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.


題意 :

  • 給一個數(shù)對a,b和一個數(shù)x,每次操作可以選擇使a或者b變成∣a?b∣|a-b|a?b(即變成它們的差值),問在若干次(0)操作后,是否能使得a或者b等于x

方案一 :

  • 如果一開始就有一個數(shù)等于x,直接true;如果一開始就兩個數(shù)都小于x,直接false,因為a和b都是正整數(shù),每次操作都會使其中一個變小
  • 對于一對(a,b),假設(shè)a>=b,考慮對a操作,此時如果通過若干次操作,使得要求被滿足,那么我們可以記為a?p?b=xa-p*b=xa?p?b=x,要使得一個正整數(shù)p存在,需要滿足a>=x,且xa>=x,且xa>=x,x%b=ab=ab=a%bbb 也就是(a?x)(a-x)(a?x)%b=0b=0b=0,當方程組被滿足時,說明有解
  • 如果當前無解,我們可以對余下的數(shù)繼續(xù)進行操作,這就相當于對(b,a(b,a(b,a%b)b)b)這一對數(shù)繼續(xù)進行求解,這一部分我們可以通過遞歸來實現(xiàn)
  • 過程中還有兩個剪枝特判,如果小的那個數(shù)為0,直接false;如果滿足上述方程組,直接true
#include <iostream>using namespace std; using ll = long long;ll a, b, x;bool check(ll a, ll b) {if (b == 0) return false;if (a >= x && a % b == x % b) return true;return check(b, a % b); }void solve() {cin >> a >> b >> x;if (a == x || b == x) cout << "Yes" << endl;else if (a < x && b < x) cout << "No" << endl;else{if (a < b) swap(a, b);cout << (check(a, b) ? "Yes" : "No") << endl;} }int main() {cin.tie(nullptr) -> sync_with_stdio(false);int _;cin >> _;while (_ -- )solve(); }

方案二 :

  • 這和 更相減損術(shù) 很像(每次迭代其中一個數(shù)變成了差值),因此想到了gcd
  • 裸gcd不一定能過,因此盡可能的剪枝
  • 講一下其中的一個剪枝。我們假設(shè)a>=b,且每次對a迭代,那么每次a都減少一個b,因此,只要a與x的差值是若干個b,那么直接剪枝判斷true
#include <iostream>using namespace std; using ll = long long;ll a, b, x;bool gcd(ll a, ll b) {if (a < b) swap(a, b); // 假設(shè)a是大的那個if (a == x || b == x) return true; // == xif (a == 0 || b == 0) return false; // x>=1if (a < x && b < x) return false; // 不可能變成x了if (a >= x && (a - x) % b == 0) return true; // 大的那個和x的差值是小的那個的倍數(shù)return gcd(a % b, b); }void solve() {cin >> a >> b >> x;if (a == x || b == x) cout << "YES" << endl;else if (a < x && b < x) cout << "NO" << endl;else cout << (gcd(a, b) ? "YES" : "NO") << endl; }int main() {cin.tie(nullptr) -> sync_with_stdio(false);int _;cin >> _;while (_ -- )solve(); }

總結(jié)

以上是生活随笔為你收集整理的X-Magic Pair gcd,剪枝(1600)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲无码久久久久久久 | 女同一区二区三区 | 免费精品无码AV片在线观看黄 | a级片视频网站 | 国产精品一线天粉嫩av | 色婷久久 | 久久午夜精品视频 | 亲子乱aⅴ一区二区三区 | 中文字幕免费中文 | hd丰满圆润的女人hd | 四虎影院永久地址 | 久久国产三级 | 精精国产xxxx视频在线 | 超碰人体 | 老头老太做爰xxx视频 | 男女在线观看视频 | 最新中文字幕在线 | 真实新婚偷拍xxxxx | 五月天中文字幕在线 | 一区二区三区中文字幕 | 亚洲高清视频在线 | 一区二区三区 中文字幕 | 鲁一鲁av | 日韩免费av一区 | 人人插人人澡 | 伊人久久五月天 | 中文字幕人妻伦伦 | 人人cao | 日韩美女做爰高潮免费 | 日本一区二区三区四区五区 | 国产精品人八做人人女人a级刘 | 91毛片视频 | 久久99影院 | 日本一区二区视频在线观看 | 国产成人精品一区二区三区在线观看 | 男生操女生屁股 | 国产suv精品一区二区68 | 亚洲欧美在线综合 | 欧美精彩视频 | 香蕉视频官方网站 | 欧美精品免费视频 | 美女福利网站 | 久久国产在线视频 | 久草久草久草 | 美女脱了内裤喂我喝尿视频 | 亚洲一区视频在线 | 美女扒开下面让男人捅 | 人妻视频一区二区三区 | 福利片av| 偷拍自拍一区 | 国产91精品高潮白浆喷水 | 国产精品一级 | 国产精品热 | 视频在线a | 葵司免费一区二区三区四区五区 | 国产欧美一区二区精品久久久 | 久久久久久久久亚洲 | 自拍第二页 | 日韩欧美国产三级 | 91午夜在线 | 黄色一级图片 | 欧美成网站 | 免费av软件 | 奇米影音 | 久久久极品 | 美国美女黄色片 | 麻豆www. | 一区二区三区日韩在线 | 影音先锋三级 | 五月天色综合 | 在线观看亚洲成人 | 老色批永久免费网站www | 免费人成视频在线播放 | 老司机深夜影院 | 香蕉福利视频 | 天天国产视频 | 国产污污| 中文字幕视频在线播放 | 波多野结衣办公室33分钟 | 亚洲人视频 | 樱花影院电视剧免费 | av毛片在线免费看 | 国产中文在线视频 | 国产又粗又硬又长又爽的演员 | 国产呦系列 | youjizz日本人| 亚洲国产精品欧美久久 | 亚洲一区二区av在线 | 欧美日韩在线免费看 | 天天干夜夜骑 | 国产精品99久久久久久大便 | www在线观看国产 | 中文字幕在线观看国产 | 美女天天干| 好吊妞视频在线观看 | 欧美熟妇精品一区二区蜜桃视频 | 麻豆视频官网 | 亚洲人xxx| 精品久久久久久久免费人妻 |