哎呀好几天没写POI题解了 (>﹏<)

看着摇曳不定的小旗子深深惶恐

打算开始肝洛谷试炼场的提高分区了【对我就是这么菜…

  • 搜索Ex

比暴搜不错得多的题

洛谷P1514 引水入城

拆成两问来看 第一问只要从湖边的城市(简称湖城)开始搜索就可以了

第二问的faulse项

用dfs剩的vis统计一下沙漠边缘有哪些点(简称沙城)没被搜到的

true项 蒟蒻一开始想状压

当然 n <= 500 【黑线

后来画了个等高线地形图【划掉

发现如果每个沙城都能有水喝【即true项

每个湖城管辖的沙城都是连续的区间

现在问题就变成了 至少用多少个区间覆盖整个区间

当然这问题长得很DP 但有个贪心更优

借用一位神犇的例子

m为10
N = 7:[1,5]、[1,6]、[3,6]、[1,7]、[6,9]、[9,10]、[7,9]。

先把每个区间(都是闭区间)排序 左区间小的优先

[1,5]、[1,6]、[1,7]、[3,6]、[6,9]、[7,9]、[9,10]

我们从1开始

选择每个区间的代价都是1 选择右区间大的显然更优

所以取[1, 7]

现在左区间小区等于7的区间 在小于等于7的部分已经被覆盖 所以无效了

为使区间连续 我们找(左区间小于等于8的区间)中(右区间最大的区间)

okk

最后附一句 如果找到一个地方 (可用最大右区间)小于(上一个取的区间的左区间)

 inline void dfs(int x, int y){
node[x][y].vis = ;
if(x < || x > n || y < || y > m) return ;
for(int i = ; i <= ; i++){
int sx = x + move[i][], sy = y + move[i][];
if(node[sx][sy].w < node[x][y].w){
if(!node[sx][sy].vis){
dfs(sx, sy);
}
node[x][y].l = min(node[sx][sy].l, node[x][y].l);
node[x][y].r = max(node[sx][sy].r, node[x][y].r);
}
}
}

dfs部分

     for(int i = ; i <= m; i++)
a[i] = (A){node[][i].l, node[][i].r};
sort(a + , a + m + , cmp);
int i = , j = , ans = ;
while(j <= m){
int k = j;
while(a[i].l <= k){
j = max(j, a[i].r);
i++;
}
j++;
ans++;
}
printf("1\n%d", ans);

贪心部分

洛谷P1242 新汉诺塔

吐槽玄学数据…

明明能一次A的wwww【委屈

 void dfs(int cur, int from, int to, bool flag){
//cur表示当前要移动的圆盘大小 from表示它在的位置 to表示它要移动到的地方
//flag = 1 表示cur是在进行主操作的点 flag = 0表示cur是为了移动另一个圆盘而移动的
if(from == to){
if(cur > ) dfs(cur - , s[cur - ], flag ? t[cur - ] : to, flag);
/*
当要移动的盘已经在它的目标位置上
如果flag = 1 那么它的主操作已经被完成 需要将主操作传递到下一个级别的圆盘上
flag = 0 那么要把下一个级别的圆盘从它的位置上移动到无关的杆子上
*/
return ;
}
if(cur > ) dfs(cur - , s[cur - ], - from - to, );
//把比它小的所有盘都移到无关的杆子上
printf("move %d from %c to %c\n", cur, turn(from), turn(to));
s[cur] = to; ans++;
//移动后 当前盘已经在目标位置上 与from == to的操作一致
if(cur > ) dfs(cur - , s[cur - ], flag ? t[cur - ] : to, flag);
}
/*
汉诺塔的框架:
将主操作从大盘向小盘传递
移动一个盘的最优策略是把它上面的盘都移到无关杆上
注意的点:
flag的传递
起点终点的选择
输出格式
结束条件(cur == 1)
*/

P1120 小木棍 [数据加强版]

啊啊啊QAQ 都是泪

有个剪枝不错

            if ( sum ==  || sum + i == target )  //
break;

搜索Ex的更多相关文章

  1. SQLSERVER走起微信公众帐号已经开通搜狗微信搜索

    SQLSERVER走起微信公众帐号已经开通搜狗微信搜索 请打开下面链接 http://weixin.sogou.com/gzh?openid=oIWsFt-hiIb_oYqQHaBMoNwRB2wM ...

  2. solr_架构案例【京东站内搜索】(附程序源代码)

    注意事项:首先要保证部署solr服务的Tomcat容器和检索solr服务中数据的Tomcat容器,它们的端口号不能发生冲突,否则web程序是不可能运行起来的. 一:solr服务的端口号.我这里的sol ...

  3. SQLServer地址搜索性能优化例子

    这是一个很久以前的例子,现在在整理资料时无意发现,就拿出来再改写分享. 1.需求 1.1 基本需求: 根据输入的地址关键字,搜索出完整的地址路径,耗时要控制在几十毫秒内. 1.2 数据库地址表结构和数 ...

  4. HTML5轻松实现搜索框提示文字点击消失---及placeholder颜色的设置

    在做搜索框的时候无意间发现html5的input里有个placeholder属性能轻松实现提示文字点击消失功能,之前还傻傻的在用js来实现类似功能... 示例 <form action=&quo ...

  5. bzoj1079--记忆化搜索

    题目大意:有n个木块排成一行,从左到右依次编号为1~n.你有k种颜色的油漆,其中第i种颜色的油漆足够涂ci个木块.所有油漆刚好足够涂满所有木块,即c1+c2+...+ck=n.相邻两个木块涂相同色显得 ...

  6. bzoj3208--记忆化搜索

    题目大意: 花花山峰峦起伏,峰顶常年被雪,Memphis打算帮花花山风景区的人员开发一个滑雪项目.    我们可以把风景区看作一个n*n的地图,每个点有它的初始高度,滑雪只能从高处往低处滑[严格大于] ...

  7. Android中通过ActionBar为标题栏添加搜索以及分享视窗

    在Android3.0之后,Google对UI导航设计上进行了一系列的改革,其中有一个非常好用的新功能就是引入的ActionBar,他用于取代3.0之前的标题栏,并提供更为丰富的导航效果.Action ...

  8. 一步步开发自己的博客 .NET版(5、Lucenne.Net 和 必应站内搜索)

    前言 这次开发的博客主要功能或特点:    第一:可以兼容各终端,特别是手机端.    第二:到时会用到大量html5,炫啊.    第三:导入博客园的精华文章,并做分类.(不要封我)    第四:做 ...

  9. Go语言实战 - 我需要站内搜索

    山坡网的用户抱怨"为什么搜索'二鬼子李富贵'找不到'二鬼子汉奸李富贵'?我用百度搜都能找到." 当时我就滴汗了,用户说的有道理,应该要能搜索到. 之前的方案很简单,用户输入的字串会 ...

  10. Entity Framework 6 Recipes 2nd Edition(13-4)译 -> 有效地创建一个搜索查询

    问题 你想用LINQ写一个搜索查询,能被转换成更有效率的SQL.另外,你想用EF的CodeFirst方式实现. 解决方案 假设你有如下Figure 13-6所示的模型 Figure 13-6. A s ...

随机推荐

  1. sql 语言

    sql 语言 DDL DDL 全称 Data Definition Language,即数据定义语言. DATABASE 创建数据库 CREATE DATABASE 语句用于创建数据库. CREATE ...

  2. 转载:(原创)odoo11配置邮件功能的那些事儿

    https://www.cnblogs.com/goyier/p/9246001.html 关于odoo的邮件服务器的配置,百度的结果是众说纷纭,但是都没有能够清楚的说明,odoo系统的邮件功能,仅仅 ...

  3. flask-script&flask-migrate使用

    一.简介 Flask-script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shell.设置数据库的脚本.cronjobs及其他运行在web应用之外的 ...

  4. 【php增删改查实例】第十三节 - EasyUI列格式化

    因为easyUI的datagrid组件是横着一格一格加载数据的,一行加载好了之后才会去加载下一行.所谓的列格式化,就是在加载某一列的所有单元格时,对即将加载到这些单元格的数据进行二次包装. 比如,我们 ...

  5. 【已解决】HeidiSQL连接(登录)MySQL数据库报错10061问题

    解决方法: 打开cmd->输入命令services.msc 然后打开即可解决.

  6. Jmeter(三十)_TimeShift函数在JSR223中的使用

    今天学习一下TimeShift函数在JSR223中的使用方法. 关联之前的一篇时间戳文章:Jmeter(十二)_打印时间戳 首先,创建线程组,在线程组下面创建一个JSR223采样器 选择Groovy语 ...

  7. os模块 与 sys模块

    os模块 os模块是与操作系统交互的一个接口 os.getcwd() 获取当前工作目录,即当前python脚本工作的目录路径 os.chdir("dirname") 改变当前脚本工 ...

  8. ELK实时日志分析平台环境部署--完整记录

    在日常运维工作中,对于系统和业务日志的处理尤为重要.今天,在这里分享一下自己部署的ELK(+Redis)-开源实时日志分析平台的记录过程(仅依据本人的实际操作为例说明,如有误述,敬请指出)~ ==== ...

  9. Centos下堡垒机Jumpserver V3.0环境部署完整记录(1)-安装篇

    由于来源身份不明.越权操作.密码泄露.数据被窃.违规操作等因素都可能会使运营的业务系统面临严重威胁,一旦发生事故,如果不能快速定位事故原因,运维人员往往就会背黑锅.几种常见的运维人员背黑锅场景:1)由 ...

  10. websocket(三)——基于node sockit.io的即时通讯

    通过前面的学习发现,常见的websocket虽然可以很好地实现服务端和客户端的信息传递,但二者之间传递的数据只是简单的字符串,这对事物的描述,信息的传递是非常不友好的,下面将引入socket.io,来 ...