当前位置: 首页 > news >正文

吉安企业做网站做网站和微信小程序

吉安企业做网站,做网站和微信小程序,做做网站需要多少钱,外贸网站建设长沙Day1 省选题 思路 取数 可反悔的贪心。我们开一个双向链表记录此时每个数的前/后一个数是什么。一个简单但不一定正确的贪心策略即为#xff1a;每次都取走当前值最大的且可取的数#xff0c;并更新列表。考虑如何使这个贪心思路正确。 设 p r e x pre_x prex​ 表示 x x …Day1 省选题 思路 取数 可反悔的贪心。我们开一个双向链表记录此时每个数的前/后一个数是什么。一个简单但不一定正确的贪心策略即为每次都取走当前值最大的且可取的数并更新列表。考虑如何使这个贪心思路正确。 设 p r e x pre_x prex​ 表示 x x x 的前一个元素 n x t x nxt_x nxtx​ 表示 x x x 的后一个元素 w ( x ) w(x) w(x) 表示 x x x 的值。则在取走 x x x 后显然 p r e x , n x t x pre_x,nxt_x prex​,nxtx​ 在这之后都不能被选取。**但如果发现选择 p r e x , n x t x pre_x,nxt_x prex​,nxtx​ 会比只选 x x x 更优呢**考虑这个贪心每轮都至少新挑出一个元素出来那么在选择 x x x 后放弃 x x x 选择了 p r e x , n x t x pre_x,nxt_x prex​,nxtx​可以理解是将 x x x 替换为后两者中的一个反悔操作并新选出了后两者中的另一个。而将 x x x 替换为 p r e x , n x t x pre_x,nxt_x prex​,nxtx​ 的收益为 w ( p r e x ) w ( n x t t ) − w ( x ) w(pre_x)w(nxt_t)-w(x) w(prex​)w(nxtt​)−w(x)所以我们就可以将这个值也当作一个可选的点继续进行贪心。 细节部分在选择了 x x x 后可以将链表中的 x x x 直接替换为 p r e x , n x t x pre_x,nxt_x prex​,nxtx​ 两点综合起来。具体地在计算完 x x x 的贡献后标记 n x t x , p r e x nxt_x,pre_x nxtx​,prex​ 这两个单独的点分别标记为已选然后就可以更新 w ( x ) ← w ( p r e x ) w ( n x t t ) − w ( x ) w(x)\gets w(pre_x)w(nxt_t)-w(x) w(x)←w(prex​)w(nxtt​)−w(x)。因为 n x t x , p r e x nxt_x,pre_x nxtx​,prex​ 都不能再单独被选所以按照正常的链表删除操作删除 p r e x , n x t x pre_x,nxt_x prex​,nxtx​ 两个单独的点。 取数2 题意即为从 n n n 个集合中各选出一个数求和求出前 k k k 大的和。为了顺应大家的习惯这里将 n , k n,k n,k 的意义调换了。 显然最大的取法就是从每个集合中取一个最大值求和我们设这个最优值为 a n s ans ans。考虑其可能的后几个略小一些的状态。我们将每个集合按照最大值减次大值的差从小到大排序每个集合内部按从大到小排序。假设当前状态 { i , j , w } \{i,j,w\} {i,j,w} 表示枚举到第 i i i 个集合中的第 j j j 个数考虑将 a n s ans ans 中第 i i i 个集合取的数更换为 j j j更换后的答案为 w w w。令 c ( i , j ) c(i,j) c(i,j) 表示集合 i i i 中第 j j j 大的值最初始的状态即为 { 1 , 2 , a n s − c ( 1 , 1 ) c ( 1 , 2 ) } \{1,2,ans-c(1,1)c(1,2)\} {1,2,ans−c(1,1)c(1,2)}。对于每个状态会有三个可能的分支 如果 j s i z i jsiz_i jsizi​则一种可能的选择即为放弃更换为 j j j考虑更换为 j 1 j1 j1。新的状态为 { i , j 1 , w − c ( i , j ) c ( i j ) } \{i,j1,w-c(i,j)c(ij)\} {i,j1,w−c(i,j)c(ij)}。如果 i i i 不是最后一个集合 一种可能的选择即为决定更换为 j j j开始考虑 i 1 i1 i1 集合的选择。新的状态为 { i 1 , 2 , w − c ( i 1 , 1 ) c ( i 1 , 2 ) } \{i1,2,w-c(i1,1)c(i1,2)\} {i1,2,w−c(i1,1)c(i1,2)}。另外如果 j 2 j2 j2则一种可能的选择即为放弃更换 i i i 中的元素直接考虑 i 1 i1 i1 集合的选择。新的状态为 { i 1 , 2 , w − c ( i , 2 ) c ( i , 1 ) − c ( i 1 , 1 ) c ( i 1 , 2 ) } \{i 1,2,w - c(i,2) c(i,1) - c(i1,1) c(i1,2)\} {i1,2,w−c(i,2)c(i,1)−c(i1,1)c(i1,2)}。 开一个优先队列记录这些状态从中取 k k k​ 轮即为答案。 文件列表 可以说是 C 语法题 直接按照题意模拟即可注意文件夹名可能会重复。 巧置挡板 暴搜剪枝。由于最终每一个矩形中都有且仅有一个 1 1 1我们不妨在搜索的过程中每次枚举所有包含某一个 1 1 1 的矩形。状态可以这样设计我们用一个长度为 n n n 的序列来表示一条从右上到左下的单调分界线序列中每一个元素表示该行分界线的位置分界线左边为搜索过的区域右边为未搜索的区域。这个状态的答案将表示完成右侧区域最少的边数。 为什么是单调的分界线在任意一种分隔方案中都一定存在一种矩形放置顺序使得每次放置之后分界线仍然是单调的。所以即使是仅考虑单调的分界线状态也一定可以搜索到所有状态这样可以简化状态降低复杂度。然而这样复杂度仍然较高。这里给出几种剪枝的手段 状态可以记忆化哈希之后用 map 存储假设某一行有一个折角分界线相比上一行发生左移如果折角的右下方没有一个 1 1 1则一定会出现空矩形不合法枚举当前矩形时 1 1 1 的个数超过 1 1 1 后可以直接停止不合法。
http://www.zqtcl.cn/news/719838/

相关文章:

  • 做论坛网站如何赚钱电子商务营销推广
  • 想要自己做一个网站怎么做济宁百度网站建设
  • 海会网络建设网站wordpress刷不出图片
  • 一个人做商城网站网站推广的几个阶段
  • 做国学类网站合法吗html5教程pdf下载
  • 云南省文化馆网站建设二级域名分发平台
  • 网站版面布局结构图网站收录批量查询
  • 网站开发手机模拟器常州到丹阳
  • 淮南医院网站建设班级网站开发报告
  • 东莞营销网站建设哪家好微信api接口
  • 凡科建站怎么导出网页wordpress视频采集插件
  • 个人介绍网站源码云主机上传网站
  • app推广平台网站系统登录入口
  • 做公司宣传册的网站成crm网
  • 新乡公司做网站军事新闻内容摘抄
  • 讯美智能网站建设泰安网络科技有限公司电话
  • 新泰建设局网站北京公司排名seo
  • 新网站上线wordpress用户登陆
  • 景安网站备案表格首页风格
  • 做网站卖菜刀需要什么手续互联网营销顾问
  • 山东鲁中公路建设有限公司网站电商网站建设任务分解结构
  • 王野苏婉卿乐清网站优化
  • 三亚市住房和城乡建设厅网站wordpress适合企业网站模板
  • php网站建设思路方案中国空间站组合体
  • 帝国+只做网站地图厦门app定制公司
  • 网站运营推广主要做什么的高匿代理ip
  • 网站建设与维护采访稿wordpress 图床加速
  • 建设国际互联网网站完整网站开发教程
  • 一个购物交易网站怎么做网站管理功能图
  • 做有后台的网站如何提交网站地图