大赛:2021省选 总结

文章目录

  • 概要
      • 想清楚再敲代码!!!
      • 仔细审题!!!
  • Day1
      • T1 卡牌游戏
      • T2 矩阵游戏
      • T3 图函数
  • day 2
      • T1 宝石
      • T2 滚榜
      • T3 支配

概要

想清楚再敲代码!!!

仔细审题!!!

第一次大赛
没有CE就算完成历史任务了
见到了赛场长什么样子
这次可贵之处应该是心态调整的很好(因为肯定选不上 );
基本发挥出了自己的水平吧(就是五个暴力+一个RE
以后考试也应该一样注意力应该在题上,不要想太多awa
预估得分(最好情况下)
t1:60
t2:30
t3:0
t4:25
t5:25
t6:30
tot=170(理想总是丰满的)
实际得分(本段写于出分后,来自洛谷数据):
(我觉得这个数据似乎有点水。。。)
t1:60
t2:30
t3:0
t4:25
t5:30
t6:5
赛后重写代码
t2:50(放四角有手就能写 +20)
t3:16(啊啊啊我打错了一个变量所以导致RE了!+16)
t5:60(阶乘算法显而易见+30)
各种原因损失得分
t1:0
t2:20(暴搜出了问题)
t3:15(老是RE)
t4:0
t5:30(没审题加先入为主)
t6:25(给出了一个伪题解思路,只混到了5分,还不如写暴力。。)
这些分要能加起来就是一个亿啊!(都说了理想总是丰满的)
此外,考场上还是有点没法进行深入思考
(回家敲支配的题解时想到的预处理思路比考场上好太多了,证明也变严谨了,发现了自己错误的原因,还发现了自己思路的bug,其实没费多少时间,而考场上是想到了一点思路就敲敲敲,蒙对了就蒙对了,写不下去就换思路重构。。。)
一方面,缺少这种限时抠较难题的机会,另一方面也是着急写代码
以后模拟难一些的题也要试试先想想正解!
如果你路过这里,可以跳过我前面的自我总结,去看看d2t3支配的题解awa
(分出来了之后应该还会再补充一些东西吧)
目前还是好弱好弱。。。11月noip时间不多了awa
目前计划:
1.好好学习
2.天天向上
2.好好刷题

Day1

这天还是有点小紧张

T1 卡牌游戏

在这里插入图片描述
在这里插入图片描述

naonao:枚举max二分min,直接乱搞切掉
这道题是我最先开始做的题
一开始我还以为是道水题。。。
最后发现我太天真了,还是用dp写了一个m^2的暴力
期望得分:60分
时间复杂度在众多暴力里似乎还算是比较好的了。。。
naonao大神的二分思路说起来其实我也不一定写不出来的
只是根本没有往二分答案的思路上去想;
对不起詹学长的集训啊。。。
说明会背板子绝不等于会了算法,我目前刷题量还是远远不够
此外,一个很大的问题是:我一开始想到dp之前,经历了在贪心,链表二分,pq之间来回的横跳
而这个横跳不是在验算纸上,而是在代码上!
敲到一般发现思路不对重新来过,浪费了大量时间;
第一题还是有点紧张
gg诚不欺我啊:想好了再敲代码!!!

T2 矩阵游戏

在这里插入图片描述
在这里插入图片描述

数学是不可能会的,暴搜天下第一!
m=2时用差分写成了1e6*n(这个是真的有手就行。。。)
剩下的就是暴搜了
但是我那个搜索出了些大问题。。。
剪枝剪来剪去把正解剪掉了。。。
再加上时间来不及了也没有调通
还不如不剪枝过前4点QWQ
暴搜n=3也过了啊!!!
期望得分:30分

T3 图函数

在这里插入图片描述
在这里插入图片描述
本题应该是本次做的最不好的一题了(废话,一分没得 );
时间不太够了也是一方面原因(你可真会找理由
本来打算反过来加边,加一次求一次,应该是m^2 * n^2(最最差的情况下,常数应该非常小,我觉得运气好能过11点的)
不知道为何在树上找联通的那个函数总是RE!!!
我现在看那个代码也不知道为啥。。。
最后,我把那个find函数的递归注释掉了。。。
这能得分就出大鬼了
期望得分:16+ 0

day 2

今天就完全放松了~ (我就是来观光的

T1 宝石

在这里插入图片描述
在这里插入图片描述
本题大脑一片空白。。。
坦坦荡荡写暴力,开开心心拿省一
这题甚至都不用LCA各种log的优化,因为反正求完暴力也得一步一步往上捡宝石
所以干脆直接一步一步爬到lca了
代码非常好写,正确性毋庸置疑。。。
复杂度:n*q
期望得分:25
半个小时直接敲完,对我来说算是做的比较成功了

T2 滚榜

在这里插入图片描述
在这里插入图片描述
本题做的很不好;
写的是暴搜所有可能性再map hash名次判重(有noi online那味了)
只能过5个点
期望得分:25
yjx大佬表示可以枚举全排列再判断,阶乘的时间复杂度可以过60
对啊!!!
这思路难想吗,不难啊
我这题做恶心了主要是因为我一开始审题审错了
以为是m分配的所有可能性
那样的话自然就是我那个写法
写完发现答案不对才发现是排名的可能情况
于是想都没想直接又加了个map加hash。。
被一开始的错误想法先入为主了
gg再次诚不欺我:看好题!!!

T3 支配

在这里插入图片描述
在这里插入图片描述

这题我想切
这题我想切
这题我想切!!
然而,最后还是暴力部分分。。。
时间复杂度:n^3+q*n
期望得分:30
我觉得我已经想到题解思路了
首先 ,我发现了一个很妙的性质:(其实也挺显然的)
若A支配B,那么支配A的所有点也一定支配B
也就是说支配具有传递性
所以对于询问新加的一条边A到B
首先肯定对A的支配集无影响
对于B来说,如果存在一个点C支配B,却不支配A,那么B的支配集就会改变(因为可以不从C走了)
反之就不会有任何改变
同时,当B支配集改变时,B支配的所有点(比如D)支配集也必然会改变
(假如B到D的路径上必须经过C,又因为C也支配B,那么显然B就不会支配D了,矛盾,所以新图C一定不会支配D)
反之,B不支配的点支配集不会改变
在这里插入图片描述

这个地方反之怎么感觉推不回来了呢。。。
比如上面这个例子,D不受B支配,但加new边后D的支配集发生了改变
这么算结果似乎会偏小
但是我用这个这个思路大数据对了好几十个输出结果都是一样的啊。。。
如果真的出来这样的问题大数据应该千差万别才对
很奇怪,我要再想一想(释然了,原来本来也切不掉

两个充要条件直接搞出了本题的题解啊!!!
B支配的点的个数可以预处理,单次询问只需要枚举B的支配集找是否支配A即可(就是找C),时间复杂度为q*n
能过20个点!
但是。。。
如何预处理支配集把我恶心到了
我一开始暴力写就是n^3
后来想建反图记忆化搜索,但输出不知为啥过个十个八个就会错一个。。。
再后来想到先把所有点支配集赋值为全部点,在图上递归遍历,同时全局标记记录一下当前路径经过了哪些点,遍历到一个点O就1-n遍历O的支配集取且运算(人话就是:只有既在当前路径上,又是O的支配集内的点才能继续当O的支配点)
这样递归遍历完每个点的支配集就应该是正确的了
一共就是把m条边都走遍,每次1-n取且运算,时间复杂度m*n
以上完全可以是一片贴在洛谷里的题解了!
但是,我考场上判重写成了按点判重,但其实每个点是可以多次遍历的!防止环的死循环应该用按边判重!!!
所以我大数据就差了很多,最后还是交的暴力30分的版本。。。
就这样,一行代码之差,AC与我失之交臂(枯了)

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

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

相关文章

ybtoj祭坛

文章目录冲啊!(100题祭)125题祭140题祭首次登顶&唯一AC150题祭160题祭170题祭冲啊!(100题祭) 2021.4.11 刚好100道 其实是前几天到的(忘了是哪一道了。。。) 今天写省选题解开了…

C++ __gnu_pbds(hash,可并堆,平衡树)

pb_ds 是GNU-C自带的一个C的扩展库&#xff0c;其中实现了很多数据结构&#xff0c;比STL里面的功能更强大 #include<ext/pb_ds/assoc_container.hpp> #include<ext/pb_ds/tree_policy.hpp> // 用tree #include<ext/pb_ds/hash_policy.hpp> // 用hash #…

理解至上:二叉堆与优先队列详细用法

文章目录二叉堆概述插入代码访问代码完整代码优先队列&#xff1a;priority_queue基本用法小根堆的声明&#xff1a;结构体注意Thanks for reading&#xff01;二叉堆 概述 为什么不用pq呢 算比较简单的数据结构了 它可以用log的时间复杂度插入元素和访问&#xff08;取出&am…

ASP.NET Core 搭配 Nginx 的真实IP问题

一.前言Nginx&#xff08;Engine X&#xff09;是一个高性能HTTP和反向代理服务&#xff0c;是由俄罗斯人伊戈尔赛索耶夫为访问量第二的Rambler.ru站点&#xff08;俄文&#xff1a;Рамблер&#xff09;开发的&#xff0c;第一个公开版本0.1.0发布于2004年10月4日。 如果…

不止代码:保留道路(ybtoj 最小生成树)

文章目录题目描述解析代码thanks for reading!题目描述 解析 其实就是修建道路 我一开始只能想到枚举g去跑最小生成树 是m^2的算法&#xff08;50pts&#xff09; 但是其实每次加入的边只有一条 而且之前都不在最小生成树上的边以后也肯定不会在 所以可以建一个新的边的集合存…

不止代码:路径数量(ybtoj-最小生成树)

文章目录题目描述解析代码题目描述 解析 乍一看&#xff1a;是个水题啊&#xff01; 显然如果途径存在强连通的点&#xff0c;路径就会变为正无穷 所以缩点加拓扑dp以及一些特判应该就可以解决了&#xff01; 一交&#xff1a;40分。。。 然后就开始拆东墙补西墙的debug。。。…

重磅!!!微软发布.NET Core 2.2

我们很高兴地宣布发布.NET Core 2.2。它包括对运行时的诊断改进&#xff0c;对ARM32 for Windows和Azure Active Directory for SQL Client的支持。此版本中最大的改进是在ASP.NET Core中。ASP.NET Core 2.2和Entity Framework Core 2.2。您可以在Windows&#xff0c;macOS和Li…

[翻译] ASP.NET Core 2.2 正式版发布

本文为翻译&#xff0c;原文地址&#xff1a;https://blogs.msdn.microsoft.com/webdev/2018/12/04/asp-net-core-2-2-available-today/我&#xff08;文章作者&#xff09;很高兴地宣布ASP.NET Core 2.2现在作为.NET Core 2.2的一部分提供&#xff01;怎么获取它您可以从 .NET…

理解至上:数位dp(ybtoj-B数计数)

文章目录简要题目描述解析dp定义:试填法代码thanks for reading&#xff01;简要 数位dp&#xff0c;天下第一 最重要的应该有两个&#xff1a; 1.状态转移式的确定 2.试填法不断往后模拟 &#xff08;至今是唯一一道数位dp&#xff0c;究竟重要的是啥我其实也没有太多经验 &am…

2021“MINIEYE杯”中国大学生算法设计超级联赛(10)Pty loves string(Border+二维数点)

Pty loves string 建立Border树后&#xff0c;发现可以转化成两个子树中相同点的数量&#xff0c;时间戳转化为连续的区间后相当于有两个数组&#xff0c;每次给两个区间&#xff0c;问区间相同点权的数目。 第一个数组作为区间&#xff0c;第二个数组作为权值。将第一个数组建…

微软推出了Cloud Native Application Bundles和开源ONNX Runtime

微软的Microsoft Connect(); 2018年的开发者大会 对Azure和IoT Edge服务进行了大量更新; Windows Presentation Foundation&#xff0c;Windows Forms和Windows UI XAML Library的开源 以及.NET 基金会会员模型的扩展。但那些只是冰山一角。微软还联合Docker发布了Cloud Native…

不止代码:友好城市(动态规划)

解析 先按左端点排序得到一个右端点的新队列&#xff0c;然后就可以发现&#xff1a; 所有合法的方案都是新队列的一个单调递增队列 然后就转化成了最长上升序列的问题 代码 #include<bits/stdc.h> using namespace std; const int N1e6100; int m,n; struct node{int…

二分图匹配(一)

文章目录什么是二分图&#xff1a;例题&#xff1a;NC111768 CF741C题目描述&#xff1a;题解&#xff1a;代码&#xff1a;二分图最大匹配匈牙利算法算法思想&#xff1a;代码&#xff1a;Knig定理二分图最优匹配KM(Kuhn-Munkres)算法算法思路&#xff1a;具体操作代码&#x…

不止代码:恐狼后卫(ybtoj-区间dp)

文章目录题目描述解析代码thanks for reading!题目描述 一代炉石的眼泪啊 解析 用dp[i][j]表示i与j之间的全部消掉&#xff08;不含两端&#xff09;的最小花费 然后枚举中间最后杀死的狼就行了 本题没有一次AC&#xff0c;因为一开始dp定义成了包含两端&#xff0c;然后因为…

牛客题霸 [二叉树的之字形层序遍历] C++题解/答案

牛客题霸 [二叉树的之字形层序遍历] C题解/答案 题目描述 给定一个二叉树&#xff0c;返回该二叉树的之字形层序遍历&#xff0c;&#xff08;第一层从左向右&#xff0c;下一层从右向左&#xff0c;一直这样交替&#xff09; 例如&#xff1a; 给定的二叉树是{3,9,20,#,#,15…

【.NET Core项目实战-统一认证平台】第九章 授权篇-使用Dapper持久化IdentityServer4...

上篇文章介绍了IdentityServer4的源码分析的内容&#xff0c;让我们知道了IdentityServer4的一些运行原理&#xff0c;这篇将介绍如何使用dapper来持久化Identityserver4&#xff0c;让我们对IdentityServer4理解更透彻&#xff0c;并优化下数据请求&#xff0c;减少不必要的开…

不止代码:生日欢唱(ybtoj-区间dp)

文章目录题目描述解析代码thanks for reading&#xff01;题目描述 解析 这题挺好的 思路&#xff1a;dp[i][j]表示必须把i和j配对&#xff0c;可达到的最大值 首先&#xff1a; dp[i][j]dp[i-1][j-1]a[i]*b[j];然后可以分别尝试把男生或女生往前放弃一段&#xff1a; for(i…

打造自己的.NET Core项目模板

前言每个人都有自己习惯的项目结构&#xff0c;有人的喜欢在项目里面建解决方案文件夹&#xff1b;有的人喜欢传统的三层命名&#xff1b;有的人喜欢单一&#xff0c;简单的项目一个csproj就搞定。。反正就是萝卜青菜&#xff0c;各有所爱。可能不同的公司对这些会有特定的要求…

超好用的C#控制台应用模板

默认模板之缺在工作学习中&#xff0c;我们经常需要创建一些简单的控制台应用(Console App)去验证某个想法&#xff0c;或者作为小工具交付给其他同事。通常我们的选择是 Visual Studio 自带的 Console App 模板&#xff0c;这个经典模板只有预设好的 csproj 文件和空荡荡的 Ma…

不止代码:区间圆数(ybtoj-数位DP)

文章目录题目描述解析理解万岁&#xff01;代码题目描述 解析 一寸山河一寸血 理解万岁&#xff01; 首先&#xff0c;这题统计[l,r]的个数&#xff0c;可以用[1,r]-[1,l-1]来实现 接下来就是如何统计出[1,n]的个数了 首先&#xff0c;用dp[pos][s0]来表示一个二进制pos位有s…