GDKOI2015 Day1

P1

题目描述:

  判断一个环形字符串(或者减去一个字符之后)是否是回文串

solution:

1.hash

  将字符串的前缀进行hash,然后将字符串翻转,再做一次hash,然后枚举对称轴,判断两边的hash值是否相等就可以了。

  时间复杂度:\( O(n) \)

2.manacher

  将字符串倍增,然后直接求最长回文串,判断是否大于等于原串长。

  时间复杂度:\( O(n) \)

P2

题目描述:

  经典网络流

solution:

  经典路径网络流,将每个点拆成入点与出点,dicnic。

   时间复杂度:\( O(52^2m) \)

P3

题目描述:

  哈密顿回路最优方案

solution:

  看题目的时候发现是哈密顿回路,但哈密顿回路是NP完全问题,数据太大了。然后发现题目有特殊性,i号点连向\( (2i)\%N \)与\( (2i+1)\%N \),N为奇数是无解的,当N为偶数时,i与\( i+\frac{N}{2} \)的入点与出点是相同的,就可以把原图缩成原来的\( \frac{1}{2} \),每条边必须走一次。这样就把哈密顿回路转化成欧拉回路(环套环搜索),题目要求最优方案就贪心一下好了。

  时间复杂度:\( O(n) \)

P4

题目描述:

  给出一棵树,每个结点有颜色和点权,支持三种操作:

  1、将子树的某两种颜色交换

  2、路径某颜色权值和

  3、改变某结点的颜色与点值。

solution:

1.树链剖分+DFS序

  这题就难在子树修改,大多数的数据结构只能修改链。同一棵子树的点在DFS序中是连续的,所以只要将树链剖分的线段树的点的顺序变成DFS序,将可以实现子树修改。每个结点记住一个对应关系,表示新的颜色对应哪种旧颜色,稍微处理一下就可以了。

  时间复杂度:\( O(nlogn) \)

2.10棵LCT

  每一种颜色开一棵LCT,维护该种颜色的结点(不是这种颜色的也要记,不过权值为0罢了),子树修改的时候直接把子树的根的父亲进行修改,而第三种操作有点麻烦,要记住树节点的地址,否则搞不清这个点究竟在那棵LCT里。

  时间复杂度:\( O(nlogn) \)  常数较大

3.ETR(Euler Tour Representation)的序列

  这是DFS序的拓展,按照时间戳来建结点,用DFS遍历这棵树,刚开始搜到这个点时在线段树建一个点(正),搜索完后再建一个点(负),这就将到根路径变成了前缀和,颜色交换是区间操作,用线段树可以完美解决。

  时间复杂度:\( O(nlogn) \)

时间: 2024-10-11 05:37:21

GDKOI2015 Day1的相关文章

学习Python的day1

自己以前从来没有写博客的想法,但是学Python,里面的老师也说了,写博客可以加深自己的记忆,也能回顾内容.还能给别人参考.挺值的.2017-09-16 一. Python介绍 python的创始人为吉多·范罗苏姆(Guido van Rossum).1989年的圣诞节期间,吉多·范罗苏姆为了在阿姆斯特丹打发时间,决心开发一个新的脚本解释程序,作为ABC语言的一种继承. 最新的TIOBE排行榜,Python赶超PHP占据第五, Python崇尚优美.清晰.简单,是一个优秀并广泛使用的语言. Py

雅礼集训——day1、day2

day1: 嗯上午考试拿了100分.第一题40,第二题60.看完题的时候我就觉得第二题的部分分是最好得到的,因为数据范围只有300,而且一眼看上去就是网络流的二分图多重匹配模型?然后就建了个网络流写了些,期望得分是70分,但是第1组数据有点劲,被卡掉了,就拿了60分.正解是map+set的贪心...并不会STL 写完T2去看T1,先用DFS乱搞了一下,结果样例都没过去,我手推了一下样例,得到了一个公式,就是从一个点出发需要加上的边数=这个点通过DFS能够遍历到的点的个数-与这个点直接相连的点的个

Linux学习日志day1——无人值守系统安装DHCP+TFTP+PXE+Kickstar

Linux学习日志day1--无人值守批量系统远程网络安装(DHCP+TFTP+PXE+Kickstar)                                         --作者:江信瀚 服务器环境介绍: 主机名:workstation.example.com 关闭SElinux以及防火墙 虚拟机:VMware(关闭了VMware的DHCP服务) 网卡配置: 静态IP获取! IPV6全部都删除,因为根本用不到 子网IP可以在VMware中设置 8.8.8.8是谷歌的DNS服务器

#6030. 【雅礼集训 2017 Day1】矩阵

#6030. 「雅礼集训 2017 Day1」矩阵 题目描述 有一个 n×n  的矩阵,每个位置 (i,j) 如果是 . 表示为白色,如果是 # 表示为黑色. 初始时,每个位置可以是黑色或白色的,(i,j)  位置的值会作为 ai,j 给你. 现在有一种操作,选择两个整数 i,j∈[1,n],记 (i,1),(i,2),…,(i,n) (i, 1), (i, 2)的颜色为 C1,C2,…Cn ??,将 (1,j),(2,j),…,(n,j)  的颜色赋为 C1,C2,…,Cn ??. 你的任务是

ZJOI2017 day1滚粗记

这几天去温州作为外省选手参加了$ZJOI day1$.打了几天的酱油,考试也滚粗了.. $day -2$ 中午从学校出发,坐飞机去温州.到了温州以后吃完晚饭就回宾馆.把一直想做的糖果公园做完了以后就堕落了一晚..玩了好久.. $day -1$ 上午听周子鑫大佬讲搜索.前几题还挺简单的,开始讲$dancing-links$以后就有点懵逼了.原理大概还是听懂了,但是完全不会实现..然后讲了很多玄学搜索题,感觉后面讲的那几题都有点懵懵懂懂,讲得好快难以接受.. 下午开始就正式进入懵逼阶段了.下午讲课一

day1作业--登录入口

作业概述: 编写一个登录入口,实现如下功能: (1)输入用户名和密码 (2)认证成功后显示欢迎信息 (3)输错三次后锁定 流程图: readme: 1.程序配置文件: 黑名单文件blacklist.txt(可以存在,可以不存在) 白名单文件whitelist.txt存在,内容如下: zhangsan,1234 wang,1234 ding,1234 2.输入密码的时候不显示 代码: 1 #coding=utf-8 2 import os 3 import getpass 4 5 BlackLis

day1 login

使用流程: 1.程序启动后,显示欢迎信息,提示用户输入用户名: 2.判断用户是否存在,不存在则提示重新输入,或者关闭程序:客户存在则提示客户输入密码: 3.判断密码是否正确,如果不正确则提示用户重新输入,输入第三次依然错误,则锁定该账户: 4.密码输入正确时,后台进程判断用户是否被禁用,“禁用”时提示用户联系管理员:没有禁用则显示登录成功欢迎信息. 系统设计: (循环登录次数增加,来禁用账户,试了 n 次,还在研究:初步实现用两个文件来实现用户验证) 1.本程序运行需要依赖两个基础文件:user

遥望布达拉——DAY1 成都-雅安

由于昨晚讨论路线加扯淡睡得比较晚,早上7点才起床,虽然以后几乎每天都这个点起,但相对于今天150km的路程,又是第一天骑需要适应节奏,注定是个悲剧.不过,不用担心,这仅仅是川藏线酸甜苦辣的开始. 先来介绍一下另外4个队友吧 左一老陈:哈尔滨人,工作三年,成熟稳重,身体综合素质较强,请了一个月假出来,骑完就要去非洲出差了,要被晒成黑球了,哈哈 右三老彭:湖北人,武汉理工大学材料学研一,骑行经验较丰富,竟然背着导师偷偷跑出来,胆儿真肥.不过他到理塘就转去稻城亚丁了,和我们只是顺路10天 右二小鹏:福

SHTSC2015 Day1

作为一名蒟蒻,今天本来就是抱着打酱油的心情去的,当然结果我依旧是打了一次酱油. 不过这个酱油打得还是要有收获的,虽然在成绩上远远落后于众位大神,但是作为一名新手还是能够从比赛中收获到不少考试经验,而这对往后的各种比赛都是很有帮助的.尤其是像信息学这种普及范围不是特别广的科目,平日里官方举办的线下赛很少,所以多多参加像省选这样的比赛就很重要了.我也感受到了上海主办方老师对于省选赛设立五次考试的良苦用心,而且费用竟然只要100元简直良心啊. 先说一下刚到考场发生的事情,简直是运气不好,我的机子鼠标没