Điểm:
1000 (p)
Thời gian:
1.0s
Bộ nhớ:
512M
Input:
bàn phím
Output:
màn hình
Bạn có hai cọc xu lần lượt chứa \(a\) và \(b\) đồng xu. Với mỗi lượt, bạn có thể loại bỏ \(1\) đồng xu ở cọc bên trái và \(2\) đồng xu ở cọc bên phải, hoặc loại bỏ \(2\) đồng xu ở cọc bên trái và \(1\) đồng xu ở cọc bên phải.
Nhiệm vụ của bạn đó chính là tìm ra liệu bạn có thể loại bỏ tất cả các đồng xu ở cả hai cọc.
Input
- Ở dòng đầu tiên chứa một số nguyên \(t\): số lượng test.
- Sau đó, có \(t\) dòng, mỗi dòng chứa hai số nguyên \(a\) và \(b\): là số lượng đồng xu ở mỗi túi.
Output
- Với mỗi test, hãy in
YES
nếu bạn có thể loại bỏ tất cả các đồng xu ở cả hai cọc và inNO
nếu ngược lại.
Constraints
- \(1 \leq t \leq 10^5\)
- \(0 \leq a, b \leq 10^9\)
Example
Sample input
3
2 1
2 2
3 3
Sample output
YES
NO
YES
Bình luận
include <iostream>
include <cmath>
using namespace std;
int main()
{
long long n,a[100000],b[100000];
cin>>n;
for (int i=1;i<=n;i++){
cin>>a[i]>>b[i];
if ((a[i]+b[i]) % 3==0 && min(a[i],b[i])>=max(a[i],b[i])/2){
cout<<"YES"<<endl;}
else{
cout<<"NO"<<endl;
}
}
return 0;
}strong text
Spoiler Alert
Để giải quyết bài toán này, chúng ta cần kiểm tra liệu có thể loại bỏ tất cả đồng xu ở cả hai cọc bằng cách sử dụng hai loại hành động đã cho.
Đặt a là số đồng xu ở cọc bên trái và b là số đồng xu ở cọc bên phải. Có hai loại hành động:
Loại bỏ 1 đồng xu ở cọc bên trái và 2 đồng xu ở cọc bên phải.
Loại bỏ 2 đồng xu ở cọc bên trái và 1 đồng xu ở cọc bên phải.
Chúng ta cần tìm ra liệu có thể giảm số đồng xu ở cả hai cọc về 0 bằng cách lặp lại hai loại hành động trên. Để làm được điều này, ta cần xem xét các điều kiện sau:
Tổng số đồng xu ở hai cọc phải chia hết cho 3(a+b mod 3 = 0). Điều này là do mỗi hành động luôn loại bỏ 3 đồng xu tổng cộng.
Không được có cọc nào có số đồng xu âm trong quá trình thực hiện các hành động. Nghĩa là, tại bất kỳ thời điểm nào, số đồng xu ở mỗi cọc phải không nhỏ hơn số đồng xu bị loại bỏ trong hành động tiếp theo.
Công thức cụ thể để kiểm tra liệu có thể loại bỏ tất cả đồng xu ở cả hai cọc là:
(a + b) mod 3 = 0 và min(a,b) >= max(a,b) // 2
Giải thích:
(a + b) mod 3 = 0:Tổng số đồng xu phải chia hết cho 3.
min(a,b) >= max(a,b) // 2: Số đồng xu ở cọc ít hơn hoặc bằng không được nhỏ hơn một nửa số đồng xu ở cọc nhiều hơn.
Code Python 3 ví dụ cho các bạn (code hơi ngu nên các bạn đừng quan tâm)
Lưu ý chỉ xem code khi các bạn quá bí ý tưởng