C - Bricks and Bags,E - Hanging Hearts,H-Leonard的子序列_树状数组优化dp,B - Hash 河南省赛

news2024/12/23 22:43:10

14天阅读挑战赛

C - Bricks and Bags

情况考虑少了,以为把最大值和最小值单独放在两个包里是最优的,其实不是,应该是分别枚举i,分别和最大值或最小值单独放在两个包里,然后去更新答案

#include<bits/stdc++.h>
#define int  long long
#define endl '\n'
#define For(i,a,b) for(i=(a);i<=(b);++i)
#define ios (ios::sync_with_stdio(false),cin.tie(0),cout.tie(0))
using namespace std;
const int N=2e6+5;
const int inf=1e18;
const int mod=998244353;
int n,a[N];

void solve()
{
    cin>>n;
    for(int i=1;i<=n;i++)
        cin>>a[i];
    sort(a+1,a+n+1);
    int ans=max(a[n]-a[1]+a[2]-a[1],a[n]-a[1]+a[n]-a[n-1]);

    for(int i=2;i<=n-2;i++)
        ans=max(ans,a[i+1]-a[i]+a[n]-a[i]);

    for(int i=3;i<=n-1;i++)
        ans=max(ans,a[i]-a[i-1]+a[i]-a[1]);


    cout<<ans<<endl;
}
signed main()
{
    //ios;
    int T;cin>>T;
    while(T--)
        solve();
    return 0;
}

E - Hanging Hearts

父节点最后的值一定是子树中最小的值,删的时候可以删一条链,也可以先把子树删完再去删子树的根节点,但这样的话子树的根节点就没有贡献了,因为他是子树的最小值,f[u][0/1]表示以u为根节点的子树删子树或者删链所能获得的最大长度

Codeforces Round #831 (Div. 1 + Div. 2) - 知乎 (zhihu.com)

#include<bits/stdc++.h>
#define int long long
#define endl '\n'
using namespace std;
const int N=2e6+100;
int n,f[N][2];
vector<int>v[N];
void dfs(int u)
{
    if(v[u].size()==0)
    {
        f[u][0]=f[u][1]=1;return;
    }
    for(auto j:v[u])
    {
        dfs(j);
        f[u][1]=max(f[u][1],f[j][1]+1);
        f[u][0]+=max(f[j][0],f[j][1]);
    }
}
signed main()
{
    cin>>n;
    for(int i=2;i<=n;i++)
    {
        int x;cin>>x;
        v[x].push_back(i);
    }
    dfs(1);
    cout<<max(f[1][0],f[1][1]);
    return 0;
}

H-Leonard的子序列_树状数组优化dp

设状态f[i]表示以a[i]为结尾的子序列长度和,那么f[i]=sum(f[j],j<i,a[j]<=a[i]/2),这个和可以用树状数组处理,但是一个树状数组好像有点办不到,开两个,t维护有多少个j是满足条件的,t2维护sum(f[j]),再开一个数组dp[i]记录满足以a[i]为结尾的子序列有多少个,那么dp[i]=ask(t),f[i]=ask(t2)+dp[i],因为转移到i后,总长度就是加了dp[i]个,起初dp[i]=f[i]=1,因为1个数也算是一个序列

#include<bits/stdc++.h>
#define int long long
#define lowbit(x) ((-x)&(x))
#define endl '\n'
using namespace std;
const int N=2e6+100;
const int mod=1e9+7;
int n,t[N],t2[N],a[N],b[N],dp[N],f[N];
void add(int x,int y)
{
    for(int i=x;i<=n;i+=lowbit(i))
        t[i]=(t[i]+y)%mod;
}
void add2(int x,int y)
{
    for(int i=x;i<=n;i+=lowbit(i))
        t2[i]=(t2[i]+y)%mod;
}
int ask(int x)
{
    int res=0;
    for(int i=x;i;i-=lowbit(i))
        res=(res+t[i])%mod;
    return res;
}
int ask2(int x)
{
    int res=0;
    for(int i=x;i;i-=lowbit(i))
        res=(res+t2[i])%mod;
    return res;
}
signed main()
{
    cin>>n;
    for(int i=1;i<=n;i++) cin>>a[i],b[i]=a[i];
    sort(b+1,b+n+1);
    int m=unique(b+1,b+n+1)-b-1;
    int ans=0;
    for(int i=1;i<=n;i++)
    {
        int id=lower_bound(b+1,b+m+1,a[i]/2LL)-b;
        if(b[id]>a[i]/2LL) id--;
        int len=ask(id),len2=ask2(id);
        dp[i]=1;f[i]=1;
        dp[i]=(dp[i]+len)%mod;
        f[i]=((f[i]+len2)%mod+len)%mod;
        id=lower_bound(b+1,b+m+1,a[i])-b;
        add(id,dp[i]);
        add2(id,f[i]);
    }
    for(int i=1;i<=n;i++)
        ans=(ans+f[i])%mod;
    cout<<ans<<endl;
    return 0;
}

B - Hash 河南省赛

经过证明可以得出子串的大小不超过15,超过16的话就不优了,感性的理解一下,我们一定是想要哈希的值不超过mod最好,因为超过了就有浪费的,而且31的次方上升的很快,所以尽可能地让子段的哈希值靠近但不超过mod是最优的,下面是题解的证明

然后dp[i]表示以i这个字母为结尾的子串所能获得的最大价值,那么dp[i]=max(dp[i],dp[j]+hash(j+1,i)),然后枚举更新答案就可以了

【CCPC】2022河南省赛补题记录-BI - 掘金 (juejin.cn)

 

#include<bits/stdc++.h>
#define int long long
#define lowbit(x) ((-x)&(x))
#define endl '\n'
using namespace std;
const int N=2e6+100;
const int mod=998244353;
const int base=31;
int dp[N],n,po[N],h[N];
char s[N];
map<char,int>mp;
int geth(int l,int r)
{
    return ((h[r]-h[l-1]*po[r-l+1]%mod)%mod+mod)%mod;
}
signed main()
{
    cin>>(s+1);
    mp['a']=1;mp['e']=2;mp['h']=3;mp['n']=4;
    n=strlen(s+1);
    po[0]=1;
    for(int i=1;i<=2*n;i++) po[i]=po[i-1]*base%mod;
    for(int i=n+1;i<=2*n;i++) s[i]=s[i-n];
    h[0]=0;
    for(int i=1;i<=2*n;i++) h[i]=(h[i-1]*base%mod+mp[s[i]])%mod;
    dp[0]=0;
    int ans=0;
    for(int k=1;k<=min(16LL,n);k++)
    {
        for(int i=1;i<=2*n;i++) dp[i]=0;
        for(int i=k;i<=k+n-1;i++)
        {
            for(int j=max(i-16LL,k-1LL);j<=i-1;j++)
            {
                dp[i]=max(dp[i],dp[j]+geth(j+1,i));
               // cout<<"dp[i]="<<dp[i]<<" dp[j]="<<dp[j]<<" geth(j+1,i)="<<geth(j+1,i)<<" i="<<i<<" j="<<j<<" k="<<k<<endl;
            }
        }
        ans=max(ans,dp[k+n-1]);
    }
    cout<<ans<<endl;
    return 0;
}

#144. DFS 序 1 - 题目 - LibreOJ (loj.ac) 树上问题转化成区间问题

处理出dfs序之后发现子树都是一段一段的,这就可以转化成区间问题,然后就是树状数组的板子了

DFS 序入门 - Planet6174 的博客 - 洛谷博客 (luogu.com.cn) 

#include<bits/stdc++.h>
#define int long long
#define lowbit(x) ((-x)&(x))
#define endl '\n'
using namespace std;
const int N=2e6+100;
const int mod=998244353;
int head[N],cnt;
struct Edge
{
    int next,to;
}e[N];
void addedge(int from,int to)
{
    e[++cnt].next=head[from];
    e[cnt].to=to;
    head[from]=cnt;
}
int num,n,m,rt,t[N],dfn[N],a[N];
void add(int x,int y)
{
    for(int i=x;i<=n;i+=lowbit(i))
        t[i]+=y;
}
int ask(int x)
{
    int res=0;
    for(int i=x;i;i-=lowbit(i))
        res+=t[i];
    return res;
}
struct node
{
    int l,r;
}p[N];
void dfs(int u,int fa)
{
    num++;
    dfn[u]=num;
    p[u].l=num;
    for(int i=head[u];i;i=e[i].next)
    {
        int j=e[i].to;
        if(j==fa) continue;
        dfs(j,u);
    }
    p[u].r=num;
}
signed main()
{
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    cin>>n>>m>>rt;
    for(int i=1;i<=n;i++) cin>>a[i];
    for(int i=1;i<n;i++)
    {
        int u,v;
        cin>>u>>v;
        addedge(u,v);
        addedge(v,u);
    }
    dfs(rt,0);
    for(int i=1;i<=n;i++) add(dfn[i],a[i]);
//    for(int i=1;i<=n;i++)
//    {
//        cout<<i<<" "<<dfn[i]<<" "<<p[i].l<<" "<<p[i].r<<endl;
//    }
    while(m--)
    {
        int x,y,op;cin>>op;
        if(op==1)
        {
            cin>>x>>y;
            add(dfn[x],y);
        }
        else
        {
            cin>>x;
            int ans=ask(p[x].r)-ask(p[x].l-1);
            cout<<ans<<endl;
        }
    }
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2397.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于stm32 ESP8266WiFi模块的基本通信

文章目录前言一、什么是ESP8266&#xff1f;二、ESP8266常用指令集三、模块的配置 及 指令的使用四、程序设计前言 本篇涉及到的模块与工具为&#xff1a; 1. ATK-ESP8266wifi模块 2. USB-UART模块 3. 串口调试助手 提取链接&#xff1a;https://pan.baidu.com/s/17xRlpnjp8j-…

软考下午题第2题——E-R图 UML图 逻辑结构设计-示题与解析

下午的第二题主要是找【属性】【主键】【外键】【候选键】之间的关系。 候选键&#xff1a;属性或者是属性组合&#xff0c;其值能够唯一地标识一个元组 主键&#xff1a;在一个关系中可能有多个候选键&#xff0c;从中选择一个作为主键 外键&#xff1a;如果一个关系中的属性或…

【JavaWeb】会话跟踪技术Cookie与Session原始真解

文章目录1 什么是会话&#xff1f;2 Cookie技术2.1 Cookie简介2.2 Cookie的理解与创建2.3 服务器获取Cookie与Cookie的修改2.4 Cookie的生命控制与生命周期2.5 Cookie有效路径Path设置3 Session会话技术3.1 初探Session3.2 Session的创建、获取与基本使用3.3 Session的生命控制…

使用Python的smtplib模块发送带附件的邮件

上一篇文章《使用Python的smtplib模块发送简单邮件》介绍了调用smtplib模块发送包含简单内容的邮件&#xff0c;本文继续学习参考文献1中的发送带附件的邮件的示例代码&#xff0c;同时由于参考文献1中的带附件邮件中并没有邮件附件&#xff0c;而仅仅是邮件内容中关联的内嵌资…

哪款半入耳式蓝牙耳机音质好?音质比较好的半入耳式蓝牙耳机推荐

半入耳式的蓝牙耳机相比入耳式的要舒适许多&#xff0c;佩戴更加的舒适透气&#xff0c;近年来&#xff0c;市面上的蓝牙耳机鱼龙混杂&#xff0c;人们选购蓝牙耳机对音质有一定的要求&#xff0c;下面是我整理的四款音质高的半入耳式蓝牙耳机&#xff0c;可以参考参考。 一、…

[carla入门教程]-1 安装carla环境

本专栏教程将记录我从安装carla到调用carla的pythonAPI进行车辆操控的全流程,带领大家从安装carla开始,到最终能够熟练使用carla仿真环境进行传感器数据采集和车辆控制. 第一节 carla 仿真环境的安装 准备工作: 在本节教程之前,需要大家安装ubuntu18.04以上的系统,并且安装对…

【MATLAB教程案例33】基于高斯混合模型的视频背景提取算法的matlab仿真实现

FPGA教程目录 MATLAB教程目录 本课程学习成果预览(左图是原始视频,右图是背景提取结果) 目录 1.软件版本 2.基于高斯混合模型的视频背景

顺序表和链表

顺序表和链表1.线性表2.顺序表2.1 概念和结构2.2 接口实现2.3 顺序表的问题及思考3.链表3.1 链表的概念和结构3.2 链表的分类3.3 链表的实现3.4 双向链表的实现4. 顺序表和链表的区别和联系1.线性表 线性表是n个具有相同特性的数据元素的有限序列。线性表是一种在实际中广泛使…

Qt 添加第三方字体库

Qt字体库默认主持操作系统所有的字体库&#xff0c;但是设计师一般喜欢比如思源字体&#xff0c;但是咱们的操作系统没有安装&#xff0c;在其他没有安装第三方字体库的电脑上运行&#xff0c;就达不到设计师最初设计的观感。这篇博客介绍Qt如何第三方字体库&#xff0c;以思源…

HTML【基础篇】

HTML【基础篇】&#x1f34e;一.HTML结构&#x1f352;1.1认识HTML标签&#x1f352;1.2HTML文件基本结构&#x1f352;1.3标签层次结构&#x1f352;1.4快速生成代码框架&#x1f34e;二.HTML常见标签&#x1f352;1.1注释标签&#x1f352;1.2标题标签&#xff08;h1-h6&…

用ADSelfService Plus更新Windows缓存的凭证

研究显示&#xff0c;帮助台技术员收到的所有电话中高达30%是因为遗忘了密码。当帮助台技术员处理大量此类电话时&#xff0c;对于来自远程的用户请求就无能为力了。这些用户使用本地缓存的Active Directory凭证来登录其机器。当该用户离开办公室时&#xff0c;帮助台技术员无法…

京东云开发者|ElasticSearch降本增效常见的方法

Elasticsearch在db_ranking 的排名又&#xff08;双叒叕&#xff09;上升了一位,如图1-1所示;由此可见es在存储领域已经蔚然成风且占有非常重要的地位。 随着Elasticsearch越来越受欢迎&#xff0c;企业花费在ES建设上的成本自然也不少。那如何减少ES的成本呢&#xff1f;今天…

某大厂软件测试岗一面笔试题+二面问答题面试经验分享

目录 某大软件测试厂笔试题 选择题 二面 某大软件测试厂笔试题 判断题(Y对&#xff0c;N错) 1.软件测试的目的是尽可能多的找出软件的缺陷。(Y) 2.Beta测试是验收测试的一种。(Y) 3.验收测试是由最终用户来实施的。(N) 4.项目立项前测试人员不需要提交任何工件。(Y) 5…

20 | 如何处理normal.mod not found

目录1 现象2 解决思路2.1 通过命令修复2.2 通过工具修复2.3 通过快照还原3 实际操作3.1 通过命令修复3.1.1 ls3.1.2 ls (hd0,X)/3.1.3 执行命令3.1.4 其他命令3.2 通过工具修复3.2.1 通过liveCD模式3.2.2 安装Boot-Repair3.2.3 修复3.3 通过快照还原1 现象 提示&#xff1a;ER…

YOLO9000: Better, Faster, Stronger (Yolov2)论文详细解读

目录前言1. Better&#xff08;更准&#xff09;2. Faster&#xff08;更快&#xff09;3. Stronger&#xff08;更壮&#xff09;前言 对应YOLOv1论文解读&#xff1a;You Only Look Once: Unified, Real-Time Object Detection&#xff08;Yolov1&#xff09; 论文详细解读 …

带你着手「Servlet」

⭐️前言⭐️ 有了前边文章为我们奠定下的网络基础&#xff0c;我们就可以开始学习Servlet的知识了&#xff0c;在部署一个Java的Servlet程序时&#xff0c;必须要有的开发工具是Tomcat,需要自行完成Tomcat的配置&#xff0c;并掌握maven仓库的配置方法&#xff0c;下边我们也…

windows下搭建mindspore的编译环境

rugwindows 10下安装mindpsore环境&#xff0c;需要visual studio 2019及以上&#xff0c;cmake, python 也可以从上面下载mindspore编译依赖的软件。 visual studioan安装时需注意 然后再安装cmake,git&#xff0c;安装好之后设置检查环境变量&#xff0c;缺失的要补上 系统…

WEB静态网页设计与制作——我的美丽家乡邢台

家乡旅游景点网页作业制作 网页代码运用了DIV盒子的使用方法&#xff0c;如盒子的嵌套、浮动、margin、border、background等属性的使用&#xff0c;外部大盒子设定居中&#xff0c;内部左中右布局&#xff0c;下方横向浮动排列&#xff0c;大学学习的前端知识点和布局方式都有…

【数据结构】顺序表OJ

文章目录0. 前言1. 移除元素2. 删除有序数组中的重复项3. 合并两个有序数组4. 结语0. 前言 在上篇博客中&#xff0c;我们使用C语言实现了顺序表。其中我们也对顺序表的接口进行了完整的实现。但是光实现不够&#xff0c;还是需要题目来练习。于是今天我就为大家带来顺序表的三…

【雷达仿真 | FMCW TDMA-MIMO毫米波雷达信号处理仿真(可修改为DDMA-MIMO)】

本文编辑&#xff1a;调皮哥的小助理 本文引用了CSDN雷达博主XXXiaojie的文章源码&#xff08;https://blog.csdn.net/Xiao_Jie1&#xff09;&#xff0c;加以修改和注释&#xff0c;全面地、详细地阐述了FMCW TDM-MIMO毫米波雷达的工作原理&#xff0c;同时配套MATLA仿真实现方…