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) \)

GDKOI2015 Day1的更多相关文章

  1. NOIp2016 Day1&Day2 解题报告

    Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...

  2. day1

    day1.py ][][: ][: ): : ]['lock'] = 0 json.dump(userlist_message, open(userlist, 'w')) break #输错次数到3次 ...

  3. day1作业--登录入口

    作业概述: 编写一个登录入口,实现如下功能: (1)输入用户名和密码 (2)认证成功后显示欢迎信息 (3)输错三次后锁定 流程图: readme: 1.程序配置文件: 黑名单文件blacklist.t ...

  4. luogu1003铺地毯[noip2011 提高组 Day1 T1]

    题目描述 为了准备一个独特的颁奖典礼,组织者在会场的一片矩形区域(可看做是平面直角坐标系的第一象限)铺上一些矩形地毯.一共有 n 张地毯,编号从 1 到n .现在将这些地毯按照编号从小到大的顺序平行于 ...

  5. Python学习路程day1

    变量起名: 变量名如果太长,推荐使用下划线来分开,让人看得清晰明白.例:nums_of_alex_girl=19 .或者是驼峰写法,即首字母大写.例:NumOfAlexGf=18 注意:不合法的变量起 ...

  6. 团队项目——站立会议 DAY1

    团队项目--站立会议 DAY1        团队成员介绍(5人):张靖颜.何玥.钟灵毓秀.赵莹.王梓萱        今日(2016/5/6)为站立会议的第一天,一起对团队项目进行讨论,并对每个人的 ...

  7. Day1 login

    使用流程: 1.程序启动后,显示欢迎信息,提示用户输入用户名: 2.判断用户是否存在,不存在则提示重新输入,或者关闭程序:客户存在则提示客户输入密码: 3.判断密码是否正确,如果不正确则提示用户重新输 ...

  8. contesthunter CH Round #64 - MFOI杯水题欢乐赛day1 solve

    http://www.contesthunter.org/contest/CH Round %2364 - MFOI杯水题欢乐赛 day1/Solve Solve CH Round #64 - MFO ...

  9. noip2011提高组day1+day2解题报告

    Day1 T1铺地毯https://www.luogu.org/problem/show?pid=1003 [题目分析] 全部读入以后从最后一个往前找,找到一个矩形的范围覆盖了这个点,那这个矩形就是最 ...

随机推荐

  1. Android Canvas不能换行,或者不识别\n,\r\n的解决方案

    在使用Canvas绘制文本的时候,如果要绘制的字符串含有\r\n,\n换行的时候,会识别不出来,当成空格绘制出来. 解决方案: 1.使用StaticLayout来实现,具体代码如下: TextPain ...

  2. 10个你必须知道的jQueryMobile代码片段

    1.在列表项和按钮上禁用文本截断     如果你的列表项或者按钮上是一个很长的文本,它将会被jQuery Mobile自动截断,要禁用这个截断设置,需要在CSS选择器上添加属性"white- ...

  3. PSR-2 Coding Style Guide

    本文主要是对PSR-2 的简单翻译. 英文源址 http://www.php-fig.org/psr/psr-2/ PSR2继承和扩展PSR1--基本编码规范 本手册的目的是使用一系列共同遵守的编码格 ...

  4. pycharm的激活

    ——————转———— Pycharm5注册方式   0x1 ,安装 0x2 , 调整时间到2038年. 0x3 ,申请30天试用 0x4, 退出pycharm 0x5, 时间调整回来. ##注册方法 ...

  5. 最全面 Nginx 入门教程 + 常用配置解析

    转自 http://blog.csdn.net/shootyou/article/details/6093562 Nginx介绍和安装 一个简单的配置文件 模块介绍 常用场景配置 进阶内容 参考资料 ...

  6. python cmd 模块

    command模块用于执行以字符串形式指定的简单系统命令,并将其输出以字符串形式返回.此模块尽在unix系统上有效.这个模型提供的功能与在unix shell脚本使用的反引号(就是~这个键下的那个反引 ...

  7. Linux学习之六-Yum命令的使用

    详细介绍一下yum命令的用法.如果你是一个Linux的初学者,一定会被软件的安装所困扰过,尽管RPM包解决了一定层度的问题,但有些RPM的包的依赖关系让人很是头疼.而YUM.APT等一些RPM包的管理 ...

  8. javascript数组去重算法-----3

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. Python 操作 MySQL--(pymysql)

    h2 { color: #fff; background-color: #7CCD7C; padding: 3px; margin: 10px 0px } h3 { color: #fff; back ...

  10. spoj 8222 Substrings (后缀自动机)

    spoj 8222 Substrings 题意:给一个字符串S,令F(x)表示S的所有长度为x的子串中,出现次数的最大值.求F(1)..F(Length(S)) 解题思路:我们构造S的SAM,那么对于 ...