C — Fibonacci Parity
Idea: Fremder
find pattern
In the defined Fibonacci sequence s, initially established with s0 = ‘0’ and s1 = ‘1’ , concatenating the last string with the second-to-last string yields alternating parity. consequently, for si , if i is even, the parity of si is even, and if i is odd, the parity of si is odd.
Upon observation, it's evident that the function f(s) generates the Fibonacci sequence starting from f(s2) . Given the established fact that every third Fibonacci number is even, we can conclude that f(s) is even for s = s2+3i and odd otherwise .
Now we got parity for nth element of both s and f(s) , compare parity of both and answer .
#include<bits/stdc++.h>
using namespace std;
#define fastio() ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL)
#define int long long
#define pb push_back
#define ppb pop_back
#define MOD 1000000007;
const int N=1e5;
void solve(){
int n;
cin >> n;
bool s = ((n%2)==0);
bool fs = ((n%3)==2);
if(s == fs){
cout << "YES";
}else cout << "NO";
cout << endl;
}
signed main() {
fastio();
int t = 1;
cin >> t;
while(t--){
solve();
}
return 0;
}
D — Subsequence Query
Idea: Fremder
prefix and suffix
#include<bits/stdc++.h>
using namespace std;
#define fastio() ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL)
#define int long long
#define pb push_back
#define ppb pop_back
#define MOD 1000000007;
const int N=1e5;
void solve(){
int m, n;
cin >> n >> m;
string s, t;
cin >> s >> t;
int index = 0;
s.insert(0, "0"); t.insert(0, "0");
vector<int> pre(n + 1), suff(n + 2);
for(int i = 1; i <= n; i++) {
if(s[i] == t[index + 1] and index<m)
index++;
pre[i] = index;
}
suff.back() = index = t.size();
for(int i = n; i > 0; i--) {
if(s[i] == t[index - 1] and index>1)
index--;
suff[i] = index;
}
int q;
cin >> q;
while(q--) {
int l, r;
cin >> l >> r;
if(suff[r + 1] - pre[l - 1] < 2)
cout << "YES\n";
else
cout << "NO\n";
}
}
signed main() {
fastio();
int t = 1;
while(t--){
solve();
}
return 0;
}
E. Destroy them All
Idea:NirbhayPaliwal
Think of humans always moving in one direction say left or right.
Think of Applying Binary Search
E. Destroy Them All
Since we are asked for non-zero probability then we just need to show one single configuration of movement such that all spots get destroyed. we can think of all humans moving together to either left or right as if it is possible to destroy all spots by splitting then it will surely be possible to destroy by all humans moving in a specific direction.
Now Let's take this whole problem as n sub-problem where answer to ith problem is number humans to be deployed on ith spot.
Now if we are able to destroy all spots by deploying k number of humans then we will surely be able to do it by deploying k+1 people. Hence to solve this sub problem we apply binary search on number of humans to be deployed, And to check for any value we will maintain one variable buff number of humans which can move, use two pointers one pointing at left side of destroyed site and other at right side And if it is possible to destroy any site by placing buff on it simply destroy it and in this way if we can destroy them all then k value returns true.
#include<bits/stdc++.h>
using namespace std;
#define int long long int
vector<int> a,b;
int n;
bool check(int key,int ind)
{
int s=ind-1,e=ind+1;
int buff=key+a[ind]; // extra people which can go to any site once their site is broken
while(s!=-1 || e!=n)
{
int flag=0 ;// to check buff changes
if(s!=-1)
{
if(a[s]+buff>=b[s])
{
buff+= a[s];
s--;
flag=1;
}
}
if(e!=n)
{
if(a[e]+buff>=b[e])
{
buff+= a[e];
e++;
flag=1;
}
}
if(!flag) return 0;
}
return 1;
}
signed main()
{
int T;
cin >> T;
while(T--)
{
cin >> n;
a.clear();b.clear();
a.resize(n);b.resize(n);
for(int i=0;i<n;i++) cin >> a[i];
for(int i=0;i<n;i++) cin >> b[i];
vector<int> ans(n);
for(int i=0;i<n;i++)
{
int lo=(b[i]-a[i]),hi=1e12;
while(hi-lo>1)
{
int mid=(hi+lo)/2;
if(check(mid,i))
{
hi=mid;
}
else
{
lo=mid+1;
}
if(check(lo,i)) ans[i]=lo;
else ans[i]=hi;
}
}
for(int i=0;i<n;i++)
{
cout << ans[i] << ' ';
}
cout << endl;
}
}
F — PAS Makeup
Idea: agrim07
Try to use DP to solve this problem
Let dp[i][p][q][turn] denote the probability of Rajat winning the game, where:
- i denotes the number of turns left,
- p denotes the parity of Rajat’s score,
- q denotes the parity of Dr. S’s score, and
- turn is 0 if it is Rajat’s turn and 1 if it is Dr. S’s turn.
Let peven and podd denote the probabilities of landing even and odd elements, respectively, among the first n−1 elements of a. We will consider the scenario where an is rolled on the die separately.
The transitions will be as follows:
If it is Rajat’s turn, then there are 2 additional cases:
Case 1: When an is odd
Case 2: When an is even
Similarly, for Dr. S’s turn:
Case 1: When an is odd
Case 2: When an is even
where pn is the probability of rolling n.