/ SeriousOJ /

Record Detail

Accepted


  
# Status Time Cost Memory Cost
#1 Accepted 1ms 332.0 KiB
#2 Accepted 2ms 332.0 KiB
#3 Accepted 158ms 812.0 KiB
#4 Accepted 152ms 856.0 KiB
#5 Accepted 165ms 1000.0 KiB
#6 Accepted 165ms 984.0 KiB
#7 Accepted 169ms 2.613 MiB
#8 Accepted 173ms 2.359 MiB
#9 Accepted 175ms 2.199 MiB
#10 Accepted 198ms 16.746 MiB
#11 Accepted 190ms 16.73 MiB
#12 Accepted 190ms 17.023 MiB
#13 Accepted 168ms 2.523 MiB
#14 Accepted 166ms 2.41 MiB
#15 Accepted 460ms 916.0 KiB
#16 Accepted 459ms 904.0 KiB
#17 Accepted 162ms 848.0 KiB
#18 Accepted 470ms 656.0 KiB
#19 Accepted 200ms 792.0 KiB
#20 Accepted 177ms 2.355 MiB
#21 Accepted 211ms 16.762 MiB
#22 Accepted 217ms 16.77 MiB
#23 Accepted 258ms 16.906 MiB
#24 Accepted 237ms 16.961 MiB
#25 Accepted 199ms 16.738 MiB
#26 Accepted 463ms 652.0 KiB
#27 Accepted 394ms 17.133 MiB

Code

#include<bits/stdc++.h>
using namespace std;
#define int             long long
#define pb              push_back
#define endl            '\n'
#define debug           cout<<"HERE"<<endl;
#define ff              first
#define ss              second
void edm()
{
    ios::sync_with_stdio(false);cin.tie(nullptr);cout.tie(nullptr);
    #ifndef ONLINE_JUDGE
    freopen("input.txt","r",stdin);
    freopen("output.txt","w",stdout);
    #endif
}
const int N = 1e5+5;
int cnt[N][20];
void solve()
{
    int n,k;cin>>n>>k;
    int arr[n+1];
    for(int i=1;i<=n;i++)cin>>arr[i];
    map<int,int>mp;
    int kk = k;
    vector<int>v;
    for(int i=2;i*i<=k;i++)
    {
        while(kk%i==0)
        {
            mp[i]++;
            kk = kk/i;
        }
    }
    if(kk!=1)mp[kk]++;
    for(auto i:mp)
    {
        v.pb(i.ff);
    }
    int koyta = mp.size();
    for(int i=1;i<=n;i++)
    {
        for(int j=0;j<v.size();j++)
        {
            while(arr[i]%v[j]==0)
            {
                cnt[i][j]++;
                arr[i] = arr[i]/v[j];
            }
        }
    }
    for(int j=0;j<koyta;j++)
    {
        for(int i=1;i<=n;i++)
        {
            cnt[i][j] = cnt[i-1][j] + cnt[i][j];
        }
    }
    int q;cin>>q;
    while(q--)
    {
        int a,b;cin>>a>>b;
        if(k==1)
        {
            cout<<"Yes"<<endl;
            continue;
        }
        int chk=1;
        for(int i=0;i<v.size();i++)
        {
            int koto = cnt[b][i] - cnt[a-1][i];
            auto it = mp.find(v[i]);
            if(it!=mp.end())
            {
               if(koto<mp[v[i]])
                {
                    chk=0;
                    break;
                } 
            }
        }
        if(chk)cout<<"Yes"<<endl;
        else cout<<"No"<<endl;
    }
    for(int i=0;i<=n;i++)
        {
            for(int j=0;j<20;j++)
            {
                cnt[i][j]=0;
            }
        }
}
int32_t main()
{
    //edm();
    int t = 1;
    cin >> t;
    for(int i=1;i<=t;i++)
    {
        solve();
    }
} 

Information

Submit By
Type
Submission
Problem
P1128 Roy and Product
Language
C++17 (G++ 13.2.0)
Submit At
2025-01-14 15:38:37
Judged At
2025-01-14 15:38:37
Judged By
Score
100
Total Time
470ms
Peak Memory
17.133 MiB