Educational Codeforces Round 175 (C.二分 D.树形结构、dp)

article/2025/6/26 6:47:00

文章目录

  • 2025.3.3
    • C. Limited Repainting(二分)
      • 题意
      • 思路
      • 代码
    • D. Tree Jumps(树形结构、dp)
      • 题意
      • 思路
      • 代码

2025.3.3

Educational Codeforces Round 175 (Rated for Div. 2)

C. Limited Repainting(二分)

题意

给出一个字符串a由“R”B“组成,不同位置对应一个惩罚值。存在一个初始全为”R“的字符串b,可以最多进行k次操作,选择b中连续区间R->B,B->R.最终罚分为a,b不匹配的位置中最大一个罚分。求可以得到的最小罚分是多少。

思路

起初,试图找规律,未果。看到标签“二分”,虽有初步判断,仍思路不明,惭愧。二分难于check,此check难于区间不定。check(x),即,凡>x者,必变。B相连,操作数为一。遇R且>x,不可变,分离变化区间或是复变此处,操作皆需+1,因而此无需多虑。凡遇之,皆+1即可。若k次即可完成操作便return1;

代码

const int N=1e6+10;
int n,k,a[N];
string s;
bool check(int x)
{int c=k,flag=0;fir(i,0,n-1){if(s[i]=='R'&&a[i]>x)flag=0;else{if(s[i]=='B'&&a[i]>x&&flag==0){if(c==0) return false;c--,flag=1;		} 		  }}return true;
}
void solve()
{cin>>n>>k;cin>>s;fir(i,0,n-1)cin>>a[i];int l=0,r=1e9;while(l<r){int mid=(l+r)/2;if(check(mid)) r=mid;else l=mid+1;}cout<<l<<'\n';
}

点击了解更多二分二分答案(模板+例题+代码)_二分答案模板-CSDN博客

D. Tree Jumps(树形结构、dp)

题意

节点1为根,1可以和与他的相邻子节点组成序列。其他节点只能和与他不在一层,且不是子节点的组成序列。求一共多少从1开始的序列。

例:

在这里插入图片描述

这个样例输入

7
1 2 2 1 4 5

输出 8

分别是 [ 1 ] [ 1 ] 、 [ 1 , 2 ] [ 1 , 2 ] 、 [ 1 , 2 , 7 ] [ 1 , 2 , 7 ] 、 [ 1 , 2 , 7 , 6 ] [ 1 , 2 , 7 , 6 ] , [ 1 , 5 ] [ 1 , 5 ] , [ 1 , 5 , 3 ] [ 1 , 5 , 3 ] , [ 1 , 5 , 3 , 6 ] [ 1 , 5 , 3 , 6 ] 和 [ 1 , 5 , 4 ] [ 1 , 5 , 4 ] [1][1] 、 [1,2][1,2] 、 [1,2,7][1,2,7] 、 [1,2,7,6][1,2,7,6] , [1,5][1,5] , [1,5,3][1,5,3] , [1,5,3,6][1,5,3,6] 和 [1,5,4][1,5,4] [1][1][1,2][1,2][1,2,7][1,2,7][1,2,7,6][1,2,7,6][1,5][1,5][1,5,3][1,5,3][1,5,3,6][1,5,3,6][1,5,4][1,5,4]

思路

思考规律,树形结构,少不了递推。可以发现以p点结尾的序列数,可以由上一层连向它,然而不能是父节点及父父节点,所以只需g【p】=sum—g【 f [ i ]】

-首先用f数组存放父节点,还需要知道父节点多少个序列,所以用g来存放每个节点的序列数。

上一层的总和递推下一层,所以要分层计算,用二维vector类型**v,存放每一层的节点。**层数如何得知呢?用数组d来计算d[i]=d[f[i]]+1。想知道每一层所有节点的序列数,就用sum不断清零、累加。每个节点的序列总和便是answer.

代码

const int N=1e6+10;
int n,a[N],f[N],d[N],g[N],mod=998244353;//f:父节点,d:结点深度,g:某节点的序列总数
void solve()
{int ans=1,sum=0;//ans 答案,sum 每层总和cin>>n;vector<int> v[n+5];//存放某层结点fir(i,2,n){cin>>f[i];//输入结点i的父节点d[i]=d[f[i]]+1;//深度=父节点+1v[d[i]].push_back(i);//结点i存入d[i]层if(f[i]==1) ans++,g[i]=1,sum++;}for(int i=2;v[i].size();i++){for(int x:v[i]){g[x]=sum,g[x]=(g[x]-g[f[x]]+mod)%mod;//该结点的序列数=上一层-父节点ans=(ans+g[x])%mod;}sum=0;for(int x:v[i]) sum=(sum+g[x])%mod;//计算该层总序列}cout<<ans<<'\n';return ;
}

注意:减法取模,需要+mod,防止出现负数


http://www.hkcw.cn/article/EqLslmsxDH.shtml

相关文章

老太突然倒地吓坏路人民警紧急相救 家属感激救命之恩

“谢谢你们帮我父亲‘捡’回一条命,再晚一会儿后果不堪设想!”5月21日,市民刘女士接到民警电话时再次表达了对紧急救援的感激之情。她的父亲76岁,患有阿尔兹海默病,下午扛着锄头出门后一直未归,家人找了3个多小时都没找到。5月19日傍晚6时许,大冶市公安局还地桥派出所接…

53岁男子诱骗侵害幼女被判刑 深挖彻查揭露更多罪行

5月29日,江苏省人民检察院召开新闻发布会,介绍了近年来加强未成年人网络司法保护的工作情况及典型案例。如皋市检察院副检察长卢海琴介绍了一起典型案例,通过深挖彻查,案件从1名被告人追到3名被告人、从1个罪名查到5个罪名、从1起强奸事实挖到19起犯罪事实、从1名被害人增加…

谷歌DeepMind最强手语翻译模型登场 打破沟通障碍

谷歌DeepMind团队于5月27日宣布推出SignGemma,这是其迄今为止最强大的手语翻译模型,能够将手语转化为口语文本。该开源模型计划在今年晚些时候加入Gemma模型家族。SignGemma支持多语言功能,但目前主要针对美国手语(ASL)和英语进行了深度优化,开发者可以自由使用并改进它。…

【C++】STL详解-----(二)vetor的使用

文章目录 vector的介绍vector的使用&#xff1a;元素访问empty vector的增删查改push_back和pop_backinsert和erase vector迭代器失效问题迭代器失效解决方法 vector的介绍 vector是可变大小数组的容器vector采用连续空间存储的方式&#xff0c;同时也表示可以采用下标访问vec…

string类

1. 为什么学习string类&#xff1f; string叫串&#xff0c;它是一个管理字符串的类&#xff0c;现实中为什么要出一个管理字符串的类呢&#xff1f;现实中我们有很多类型&#xff0c;比如int、double、char等&#xff0c;但发现这个世界的一些复杂东西都是通过字符串表示的…

潍坊烟花秀压轴项目缺席遭吐槽 设备故障引争议

多名网友在社交平台发帖表示,5月30日晚他们参加了潍坊世界风筝乐园的烟花秀表演,单人票198元,双人票298元。然而,之前宣传的压轴项目“七彩祥云”并未出现,引发观众不满。潍坊世界风筝乐园工作人员解释称,由于设备故障,“七彩祥云”环节被迫取消,并且当晚和接下来两天的…

江苏城市足球联赛为何这么火 赛事带动文旅热潮

最近,2025年江苏省城市足球联赛“苏超”火了。从“比赛第一,友谊第十四”到各地纷纷推出“跟着赛事游江苏”的文旅优惠,以足球为媒,以赛事为桥,江苏展现了独特的魅力。自5月10日揭幕以来,“苏超”迅速走红,成为江苏省乃至全国关注的热点。你以为“苏超”只是踢踢比赛?殊…

汪涵体验问界M9五座零重力座椅 舒适到不想起

汪涵体验了问界M9的零重力座椅,表情十分享受。这款座椅采用零压感知人体工学专利设计,腰部零压角为121,腿部零压角为136,能够使全身压力均匀分布,带来零压悬浮感。汪涵坐在上面久久不愿起身,甚至在车展主持时也选择躺着进行,这种舒适度让人非常心动。责任编辑:0882

德国为何要解除对援乌武器射程限制 西方军援策略重大转变

2025年5月28日,德国新当选总理弗里德里希默茨在柏林宣布,乌克兰的西方盟友将取消向基辅供应武器的射程限制。这一政策调整涵盖美国、英国、法国和德国等主要援乌国家,标志着西方对乌军援策略的重大转变,随即引发国际社会对俄乌冲突走向的强烈关注。在WDR组织的论坛上,默茨…

Nginx基础篇(Nginx目录结构分析、Nginx的启用方式和停止方式、Nginx配置文件nginx.conf文件的结构、Nginx基础配置实战)

文章目录 1. Nginx目录结构分析1.1 conf目录1.2 html目录1.3 logs目录1.4 sbin目录 2. Nginx的启用方式和停止方式2.1 信号控制2.1.1 信号2.1.2 调用命令 2.2 命令行控制2.2.1 基础操作类2.2.2 配置测试类2.2.3 进程控制类2.2.4 路径与文件类2.2.5 高级配置类 3. Nginx配置文件…

印军高层被追问是否与巴方会面 印空军将领打马虎眼

印巴停火协议签署后,两国都在宣称自己取得了胜利。然而,印度军方的表现却让人失望。5月11日,印度空军中将巴蒂召开记者会,面对记者们的追问,他声称印度空军在这次冲突中表现出色,并坚称打下了好几架巴基斯坦飞机。但当被问及具体数字时,他却表示“不想冒险猜测”,并解释…

大V:辽宁舰率海军最强编队驶入西太 展现惊人实力

自去年10月在南海与山东舰稍微展示了一下双航母的实力后,辽宁舰到今年5月中旬都没有什么动作,大家的目光都放在了更出色的山东舰和福建舰上。然而,辽宁舰在5月下旬南下西太平洋,展示了强大的实力。护航编队包括两艘055型驱逐舰、五艘052D型驱逐舰和三艘054A型护卫舰,再加上…

印度刚喊话巴基斯坦,转头联合蒙古军演?背后算盘藏不住了!

印度最近的一系列举动引起了广泛关注。不久前,印度还在与巴基斯坦紧张对峙,并放狠话威胁对方,紧接着又派了一个大型商业代表团访问台湾。更令人意外的是,印度现在绕过中国,直接与蒙古国进行联合军事演习。这种行为就像是小孩子打架,正面打不过就绕到背后捅手指头。然而,…

25艘龙船巡游广州荔湾湖 展现广府龙舟文化魅力

5月31日,第十五届“荔枝湾新西关”民俗文化活动“五月五龙船鼓”在广州荔湾湖公园盛大开幕。上午8时30分,十多艘来自南海盐步、坑口、茶滘等地的龙船装饰一新,从珠江口岸徐徐进入荔湾湖面,与泮塘村的龙船一同趁景。泮塘村的龙船作为东道主,率先引领着各兄弟村的龙船队伍绕…

河南鹤壁一水库水位下降现千佛石窟 千年佛像重见天日

近日,有网友发布视频显示,河南省鹤壁市淇县夺丰水库水位下降后,露出一处石洞。这处石洞虽然洞口不大,但内部却别有洞天,四周布满佛像,造型精细,栩栩如生。洞内还有较深的积水。不少网友称这个洞为千佛洞,并有人前来打卡。该石窟名为前嘴石窟,开凿于东魏时期,千百年来…

全世界都在划龙舟过端午 全球共庆文化盛宴

当农历五月的暖风拂过东亚的稻田,粽叶的清香飘荡在东南亚的街巷,龙舟的鼓点响彻欧美的河流,全世界共同庆祝源自中国的古老节日——端午节。这个绵延两千多年的传统节日,早已超越地域界限,成为人类共享的文化盛宴。在中国,从江南水乡到北国平原,家家户户清晨便飘起蒸煮粽…

美禁运C919发动机 破局之道在哪里 核心技术自主可控

没有发动机,中国的大飞机还能飞吗?当美国突然暂停向中国商飞出售航空发动机技术时,这个问题迅速引起广泛关注。西方媒体纷纷唱衰“C919即将搁浅”,而中国外交部则强硬回击,坚决反对这种恶意封锁。这场看似突如其来的问题,实际上揭示了中美科技竞争的深层次矛盾——中国航…

python调用C++ DLL

使用C创建动态链接库&#xff1a; dllmain.cpp #include <windows.h> #include <string> #include <vector> #include "opencv2/opencv.hpp"BOOL APIENTRY DllMain(HMODULE hModule, DWORD ul_reason_for_call, LPVOID lpReserved) {return TRUE…

多米尼加坍塌事故死亡人数升至234人 全国哀悼日持续六天

当地时间5月31日,多米尼加医疗中心报告称,一名在俱乐部屋顶坍塌事故中的重症患者不幸去世,使得该事故的死亡人数上升至234人。这起事故发生在4月8日凌晨,地点是多米尼加首都圣多明各的一家俱乐部。当时俱乐部内正在举行知名歌手的演出,突然倒塌的屋顶导致许多人被埋在废墟…

姜广涛仅剩光合积木一家公司存续 配音演员告别引发关注

5月31日,多名配音演员宣布离开光合积木,未来将以自由人的身份继续参与配音工作,但与光合积木仍会保持项目上的合作。姜广涛也发文表示自己仍在学习的路上,并祝愿同事们在配音道路上继续前行,开启新的篇章。企查查数据显示,姜广涛目前仅关联一家存续状态的企业——北京光合…