/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 332.0 KiB
#2 Accepted 2ms 540.0 KiB
#3 Accepted 115ms 788.0 KiB
#4 Accepted 118ms 832.0 KiB
#5 Accepted 129ms 876.0 KiB
#6 Accepted 131ms 964.0 KiB
#7 Accepted 153ms 1.344 MiB
#8 Accepted 148ms 1.211 MiB
#9 Accepted 150ms 1.129 MiB
#10 Accepted 167ms 4.59 MiB
#11 Accepted 167ms 4.672 MiB
#12 Accepted 171ms 4.57 MiB
#13 Accepted 147ms 1.285 MiB
#14 Accepted 151ms 1.27 MiB
#15 Accepted 114ms 836.0 KiB
#16 Accepted 113ms 852.0 KiB
#17 Accepted 115ms 788.0 KiB
#18 Accepted 123ms 836.0 KiB
#19 Accepted 130ms 1020.0 KiB
#20 Accepted 153ms 1.047 MiB
#21 Accepted 165ms 4.719 MiB
#22 Accepted 167ms 4.566 MiB
#23 Accepted 171ms 4.801 MiB
#24 Accepted 164ms 4.816 MiB
#25 Accepted 170ms 4.711 MiB
#26 Accepted 116ms 832.0 KiB
#27 Accepted 334ms 5.207 MiB

Code

#include<bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
typedef long long int ll;


using namespace std;
using namespace __gnu_pbds;
#define ordered_set tree<int, null_type,less<int>, rb_tree_tag,tree_order_statistics_node_update>
#define mod 1000000007

ll x;

ll lcm(ll a,ll b)
{
    return (a*b)/__gcd(a,b);
}


ll binExp(ll a,ll b)
{
    if(b==0)
        return 1;

    ll res=binExp(a,b/2);

    if(b&1)
    {
        return (a*res*res)%mod;

    }
    else
    {
        return (res*res)%mod;
    }
}


bool isPrime(long long  n)
{
    if (n <= 1)
        return false;
    if (n <= 3)
        return true;
    if (n % 2 == 0 || n % 3 == 0)
        return false;

    for (long long i = 5; i * i <= n; i += 6)
    {
        if (n % i == 0 || n % (i + 2) == 0)
            return false;
    }

    return true;
}

class DisjointSet
{

public:
    vector<ll> parent,rnk,sz;
    DisjointSet(ll n)
    {
        rnk.resize(n+1,0);
        parent.resize(n+1);
        sz.resize(n+1);

        for(ll i=0; i<=n; i++)
        {
            parent[i]=i;
            sz[i]=1;
        }
    }

    ll findUPar(ll node)
    {
        if(node==parent[node])
        {
            return node;
        }
        return parent[node]=findUPar(parent[node]);
    }

    bool unionByRank(ll u,ll v)
    {
        ll ulp_u=findUPar(u);
        ll ulp_v=findUPar(v);

        if(ulp_u==ulp_v)
        {
            return false;
        }
        if(rnk[ulp_u]==rnk[ulp_v])
        {
            parent[ulp_u]=ulp_v;
            rnk[ulp_v]++;
        }
        else if(rnk[ulp_u]<rnk[ulp_v])
        {
            parent[ulp_u]=ulp_v;
        }
        else if(rnk[ulp_v]<rnk[ulp_u])
        {
            parent[ulp_v]=ulp_u;
        }
        return true;
    }

    bool unionBYSize(ll u,ll v)
    {
        ll ulp_u=findUPar(u);
        ll ulp_v=findUPar(v);
        if(ulp_u==ulp_v)
            return false;

        if(sz[ulp_u]<sz[ulp_v])
        {
            parent[ulp_u]=ulp_v;
            sz[ulp_v]+=sz[ulp_u];
        }
        else
        {
            parent[ulp_v]=ulp_u;
            sz[ulp_v]+=sz[ulp_u];
        }
        return true;
    }




};

class segmentTree
{

    vector<ll> segArray;

public:
    segmentTree(ll n)
    {
        segArray.resize(4*n);
    }

    void build(ll index,ll low,ll high,vector<ll> &arr)
    {
        if(low==high)
        {
            segArray[index]=arr[low];
            return;
        }

        ll mid = (low+high)/2;

        build(2*index+1,low,mid,arr);
        build(2*index+2,mid+1,high,arr);

        segArray[index] = ((segArray[2*index+1]*segArray[2*index+2])%x);
    }

    ll query(ll index,ll low,ll high,ll l,ll r)
    {
        // no overlap
        ///[low high l r] or [l r low high]

        if(high<l || low>r)
        {
            return 1;
        }


        // Complete Overlap
        /// [l low high r]

        if(low>=l && high<=r)
        {
            return segArray[index];
        }

        /// Partial overlap

        ll mid = (low+high)/2;

        ll left=query(2*index+1,low,mid,l,r);
        ll right=query(2*index+2,mid+1,high,l,r);

        return ((left*right)%x);


    }




};




void solve()
{
    ll n;
    cin>>n>>x;

    vector<ll> arr(n);

    for(ll i=0; i<n; i++)
    {
        cin>>arr[i];
    }

    segmentTree sgt(n);

    sgt.build(0,0,n-1,arr);

    ll q;
    cin>>q;


    while(q--)
    {
        ll a,b;
        cin>>a>>b;
        a--;
        b--;

        ll temp=sgt.query(0,0,n-1,a,b);

        if(temp==0)
        {
            cout<<"Yes"<<endl;
        }
        else
        {
            cout<<"No"<<endl;
        }
    }


}


























int main()
{


    ios_base::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);





    ll t;

    cin>>t;
    //t=1;






    ll caseNo=1;



    while(t--)
    {
        //cout<<"Case "<<caseNo<<": ";
        // caseNo++;

        solve();


    }


    return 0;




}







Information

Submit By
Type
Submission
Problem
P1128 Roy and Product
Contest
Brain Booster #7
Language
C++17 (G++ 13.2.0)
Submit At
2024-11-05 16:06:19
Judged At
2024-11-05 16:06:19
Judged By
Score
100
Total Time
334ms
Peak Memory
5.207 MiB