2017 ACM Jordanian Collegiate J.Efficiency Test 动态规划、类倍增

题目

题目链接

题解及代码

#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
const int N = 1e5+7;
int f[2*N][55],a[2*N],sum[2*N],ans[2*N],pb[2*N];
int T,n,k;
#define pr(x) cout<<#x<<":"<<x<<endl
/** 题解* 由于最多跳一个环就结束,因此倍长数组就足够了。* 预处理出f[i][j]表示从i点出发,每次跳j步,最远能跳到哪里。* 预处理出sum[i]表示数组[1,i]位置中有多少个'#'。* 预处理出pb[i],表示i位置前面距离最近的'#'的位置。* ans数组为存储最终答案的数组。* 枚举出发点i,再从大到小枚举跳跃长度m,很容易得到f[i][m]得到下一个点nxt,* 如果nxt不为0,则表示可以走,为了避免多跳,我们把nxt和pb[i]+1取一个最小值,* 然后ans[i] += ceil((nxt-now)/m);* 并更新now = nxt;* 这样的话,总的时间复杂度就是O(nk)*/
int main(){freopen("jumps.in","r",stdin);cin>>T;while(T--){cin>>n>>k;memset(f,0,sizeof(f));memset(sum,0,sizeof(sum));memset(a,0,sizeof(a));memset(ans,0,sizeof(ans));for(int i = 1;i <= n;++i){char c;scanf(" %c",&c);if(c == '#') a[i] = 1;sum[i] = sum[i-1] + a[i];}for(int i = n+1;i <= 2*n;++i){a[i] = a[i-n];sum[i] = sum[i-1] + a[i];}sum[2*n+1] = sum[2*n];int pre = 0;for(int i = 1;i <= 2*n;++i){if(a[i]) pre = i;else pb[i] = pre;}for(int i = 2*n;i;--i) for(int m = k;m;--m){if(a[i]) continue;int t = m + i;if(t > 2*n){if(!a[t-2*n] && sum[2*n]-sum[i]+sum[t-2*n] <= 1)f[i][m] = 2*n+1;}else{if(!a[t] && sum[t]-sum[i] <= 1)f[i][m] = max(f[t][m],t);}}for(int i = 1;i <= n;++i){if(a[i]) continue;int it = i;for(int m = k;m;--m){int nxt = f[it][m];if(nxt) {if(nxt > pb[i+n]) nxt = pb[i+n]+1;ans[i] += (nxt-it) / m;if((nxt-it)%m) ans[i]++;it = nxt;}if(it > pb[i+n]) break;}if(it < pb[i+n]) ans[i] = -1;}for(int i = 1;i <= n;++i){if(i != 1) cout<<' ';cout<<ans[i];}cout<<endl;}return 0;
}

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

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

相关文章

P3041-[USACO12JAN]Video Game G【AC自动机,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P3041 题目大意 输入nnn个只有ABCABCABC的字符串&#xff0c;求一个长度为LLL的字符串中最多包含多少个子串是nnn个字符串中的一个 解题思路 考虑ACACAC自动机是如何进行匹配的&#xff0c;对于下一个字符&#xff0c;如果有…

【DFS】排排坐

排排坐 题目大意&#xff1a; 有n个方块&#xff0c;有一些是黑色&#xff0c;有一些是白色&#xff0c;可以点击一个方块使它和它旁边的方块反转颜色&#xff08;黑变白&#xff0c;白变黑&#xff09;&#xff0c;问最少要点多少次才能将方块 们 变成目标的方块们&#xff…

用ASP.NET Core 2.1 建立规范的 REST API -- 保护API和其它

预备知识: 用ASP.NET Core 2.0 建立规范的 REST API -- 预备知识 用ASP.NET Core 2.0 建立规范的 REST API -- 预备知识 (2) 准备项目建立成熟度2级的 API请看这里&#xff1a;用ASP.NET Core 2.0 建立规范的 REST API -- GET 和 POST, 用ASP.NET Core 2.0 建立规范的 REST AP…

CERC2017 Gambling Guide,最短路变形,期望dp

题目链接 题面链接 题意 给定一个无向图&#xff0c;你需要从11点出发到达n" role="presentation" style="position: relative;">nn点&#xff0c;你在每一点的时候&#xff0c;使用11个单位的代价,随机得到相邻点的票,但是你可以选择留在原地…

P4045-[JSOI2009]密码【AC自动机,状压dp】

正题 题目链接:https://www.luogu.com.cn/problem/P4045 题目大意 给nnn个字符串&#xff0c;求有多少个长度为lll的字符串包含所有给出的字符串 解题思路 因为nnn很小&#xff0c;考虑状压dpdpdp&#xff0c;因为是包含所有字符串&#xff0c;考虑在ACACAC自动机上dpdpdp。…

华为资深工程师:码农很多,但程序员并不多......

“春节假期&#xff0c;与几位友人小聚&#xff0c;大家互道工作顺利、平安健康云云......期间一位驰骋商界多年的老友问&#xff1a;“你现在在华为做什么工作呀?”我很骄傲地说&#xff1a;”系统架构师“&#xff0c;可是他却愣了很久。但当我老婆在旁边补上一句“码农“时…

【DP】【递归】分离与合体

分离与合体 题目大意&#xff1a; 有n个区域&#xff0c;可以把它们分为两个区间&#xff0c;结果加上左边区间的最左区域的数和最右区域的数还有右边区间的最右区域的数&#xff0c;就这样不停分&#xff0c;使结果最大&#xff0c;并输出各分界线的位置&#xff08;按1/2,2…

NEERC2017 Laminar Family 树链剖分+LCA

题目链接 http://codeforces.com/gym/101630/attachments/download/6401/20172018-acmicpc-northeastern-european-regional-contest-neerc-17-en.pdf 题意 给出一棵树和一组操作&#xff0c;操作的格式是给出u、vu、v两个节点&#xff0c;并将该节点所确定的路径上的节点全…

CF1009F-Dominant Indices【长链剖分】

正题 题目链接:https://www.luogu.com.cn/problem/CF1009F 题目大意 以1为根的一棵树&#xff0c;对于每个节点xxx求一个最小的kkk使得以xxx为根的子树中第kkk层的结点最多。 解题思路 我们先进行一次长链剖分&#xff0c;对于一个长链我们可以发现如果每次往下做的话&#…

VS2017 15.8第二个预览版本提升了对CPU Profiling和F#的支持

VS2017 15.8第一个预览版本的特性包括对ARM64构建的支持、ASP.NET Core对Docker的支持以及重新引入LibMan。在15.8的第二个预览版本中&#xff0c;微软发布了一个新Google Android模拟器的预览功能&#xff0c;它能够与Hyper-V兼容。这样的话&#xff0c;最新的Android模拟器就…

【SPFA】腾讯大战360

腾讯大战360 题目大意&#xff1a; 有n个点&#xff0c;还有m条线连接着这些点&#xff0c;有两个人在其中两个点上&#xff0c;让这两个人相遇最快要多久 原题&#xff1a; 题目描述 2010年11月3日&#xff0c;是一个难忘的日子。 腾讯发布消息&#xff1a;存360则&#…

一道有趣的最短路 NEERC2017 Journey from Petersburg to Moscow

题目链接 http://codeforces.com/gym/101630/attachments/download/6401/20172018-acmicpc-northeastern-european-regional-contest-neerc-17-en.pdf 题意 求11到n" role="presentation" style="position: relative;">nn的最短路&#xff0c;最…

P5904-[POI2014]HOT-Hotels加强版【长链剖分,dp】

正题 题目链接:https://www.luogu.com.cn/problem/P5904 题目大意 nnn个点的一棵树&#xff0c;求有多少个点对(i,j,k)(i,j,k)(i,j,k)使得这三个点距离相等。 解题思路 有两种情况&#xff0c;一是iii是j,kj,kj,k的祖先&#xff0c;二是i,j,ki,j,ki,j,k互相没有祖先关系 考虑…

初一级模拟试题总结(2019.3.2)

成绩 rank算上了其他大佬 rankrankranknamenamenamescorescorescoreT1T1T1T2T2T2T3T3T3T4T4T4111lyflyflyf400400400100100100100100100100100100100100100111wjjwjjwjj280280280100100100808080000100100100111tjhtjhtjh200200200100100100000000100100100111fyfyfy200200200…

ASP.NET Core Razor生成Html静态文件

一、前言最近做项目的时候&#xff0c;使用Util进行开发&#xff0c;使用Razor写前端页面。初次使用感觉还是不大习惯&#xff0c;之前都是前后端分离的方式开发的&#xff0c;但是使用Util封装后的Angular后&#xff0c;感觉开发效率还是杠杠滴。二、问题在发布代码的时候&…

NEERC2017 Archery Tournament 线段树 新套路

题目链接 http://codeforces.com/gym/101630/attachments/download/6401/20172018-acmicpc-northeastern-european-regional-contest-neerc-17-en.pdf 题意 给出一些圆&#xff0c;这些圆圆心在x轴上方&#xff0c;且与x轴相切&#xff0c;任意时刻&#xff0c;不存在图上的…

P2178-[NOI2015]品酒大会【SA,并查集】

正题 题目链接:https://www.luogu.com.cn/problem/P2178 题目大意 长度为nnn的字符串&#xff0c;每个位置有一个权值。 如果对于q,pq,pq,p有sq,qr−1sp,pr−1s_{q,qr-1}s_{p,pr-1}sq,qr−1​sp,pr−1​那么就称q,pq,pq,p为rrr相似。 对于每个rrr求有多少对q,pq,pq,p是rrr相似…

【Floyed】【最短路】商店选址问题(ssl 1760)

商店选址问题 ssl 1760 题目大意&#xff1a; 有一些点&#xff0c;在一个点上按医院&#xff0c;有一个值就是这个点到其他点的最短路之和&#xff0c;问这个值最小是多少 原题&#xff1a; Description 给出一个城市的地图&#xff08;用邻接矩阵表示&#xff09;&…

一文看懂.NET的各种变体

曾几何时&#xff0c;我们只有一个.NET&#xff0c;叫作.NET Framework。如果想要开发.NET应用程序&#xff0c;只要使用.NET Framework即可&#xff0c;非常简单。几年之后&#xff0c;出现了.NET变种的寒武纪大爆发&#xff08;我们称之为“.NET大爆炸”&#xff09;&#xf…

Codeforces Gym - 100917 部分题解

A.Abstract Picture Gym - 100917A 分析&#xff1a;由于最后刷的一笔肯定使得某一行或者是某一列均为相同的颜色。 因此我们可以在一开始找到所有的行或者列&#xff0c;他们的颜色全都一样&#xff0c;把这样的行或列加入到队列里面去。 我们处理在队列里面的行或者列&…