Codeforces Round 1042 (Div. 3)

ABCD 略

E

注意到每个操作最多执行一次,ifa[i]!=b[i],要么a[i]^a[i+1]要么a[i]^b[i+1]

G

设消除1~i的数的操作次数为f[i],可以推出f[i]=2*f[i-1]+1,那么消除1~i的数的分数乘的数为g[i],g[i]=g[i-1]*g[i-1]*i s虽然很大,但是k只有1e9,先预处理fg,并且得到最大可以消除它和它衍生得到的数m。把所有数放到set,从小到大判断每个数及它的衍生数是否可以完全消去,可以则直接消去计算价值,否则拆乘成小于m的若干个数。思考会不会超时,答案是不会,像这种无法完全删去的情况最多出现m次,每次最多循环m

复制代码
#include<bits/stdc++.h>
using namespace std;
#define endl '\n'
#define int long long
const int N=2e5+10,mod=1e9+7;
int T,n,m,k,a[N],f[N],g[N],ans;
void init()
{
    ans=1;
}
void solve()
{
    cin>>n>>k;
    init();
    set<int> s;
    for(int i=1;i<=n;i++)
    {
       cin>>a[i];
       s.insert(a[i]);
    }
    while(s.size()&&k)
    {
        int x=*s.begin();
        s.erase(s.begin());
        if(x<=m&&k>=f[x-1]+1)
        {
            ans=(ans*g[x-1]%mod*x)%mod;
            k-=f[x-1]+1;
        }
        else
        {
            ans=(ans*x)%mod;
            for(int i=1;i<min(m+1,x);i++)
            s.insert(i);
            k--;
        }
    }
    cout<<ans<<endl;
}
signed main()
{
    f[0]=0;g[0]=1;
    for(m=1;;m++)
    {
        f[m]=f[m-1]*2+1;
        g[m]=(g[m-1]*g[m-1]%mod*m)%mod;
        if(f[m]>1e9) break;
    }
    ios::sync_with_stdio(0);
	cin.tie(0);cout.tie();
    cin>>T;
    while(T--) solve();
}
相关推荐
纽扣6678 分钟前
【算法进阶之路】链表核心:快慢指针与反转链表专题精讲
数据结构·c++·算法·链表
lzh2004091914 分钟前
Linux管道(Pipe)深度指南:从原理到实战
linux·c++
eDEs OLDE16 分钟前
CC++链接数据库(MySQL)超级详细指南
c语言·数据库·c++
浅念-19 分钟前
吃透栈:LeetCode 栈算法题全解析
数据结构·c++·算法·leetcode·职场和发展·
吟安安安安20 分钟前
【算法设计与分析】第一讲 算法基础(上)
算法
阿Y加油吧20 分钟前
二刷 LeetCode:62. 不同路径 & 64. 最小路径和 复盘笔记
笔记·算法·leetcode
NQBJT22 分钟前
双轮足导盲机器人:多传感融合与全局-局部分层导航系统设计
c++·esp32·openmv·避障·导盲·轮足
lzh2004091923 分钟前
Linux信号(Signal)
linux·c++
生成论实验室25 分钟前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》导论:在破碎的世界寻找统一语法
人工智能·科技·算法·架构·创业创新
承渊政道26 分钟前
【动态规划算法】(两个数组的DP问题深度剖析与求解方法)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法