日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

X-Magic Pair gcd,剪枝(1600)

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


題意 :

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

方案一 :

  • 如果一開始就有一個(gè)數(shù)等于x,直接true;如果一開始就兩個(gè)數(shù)都小于x,直接false,因?yàn)閍和b都是正整數(shù),每次操作都會使其中一個(gè)變小
  • 對于一對(a,b),假設(shè)a>=b,考慮對a操作,此時(shí)如果通過若干次操作,使得要求被滿足,那么我們可以記為a?p?b=xa-p*b=xa?p?b=x,要使得一個(gè)正整數(shù)p存在,需要滿足a>=x,且xa>=x,且xa>=x,x%b=ab=ab=a%bbb 也就是(a?x)(a-x)(a?x)%b=0b=0b=0,當(dāng)方程組被滿足時(shí),說明有解
  • 如果當(dāng)前無解,我們可以對余下的數(shù)繼續(xù)進(jìn)行操作,這就相當(dāng)于對(b,a(b,a(b,a%b)b)b)這一對數(shù)繼續(xù)進(jìn)行求解,這一部分我們可以通過遞歸來實(shí)現(xiàn)
  • 過程中還有兩個(gè)剪枝特判,如果小的那個(gè)數(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ù) 很像(每次迭代其中一個(gè)數(shù)變成了差值),因此想到了gcd
  • 裸gcd不一定能過,因此盡可能的剪枝
  • 講一下其中的一個(gè)剪枝。我們假設(shè)a>=b,且每次對a迭代,那么每次a都減少一個(gè)b,因此,只要a與x的差值是若干個(gè)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是大的那個(gè)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; // 大的那個(gè)和x的差值是小的那個(gè)的倍數(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)容還不錯(cuò),歡迎將生活随笔推薦給好友。