多维DP UVA 11552 Fewest Flop

 

题目传送门

 1 /*
 2     题意:将子符串分成k组,每组的字符顺序任意,问改变后的字符串最少有多少块
 3     三维DP:可以知道,每一组的最少块是确定的,问题就在于组与组之间可能会合并块,总块数会-1。
 4         dp[i][j]表示第i组以第j个字符结尾的最少块数,状态转移方程:dp[i][j] = min (dp[i][j], dp[i-1][l] + chunk - 1);
 5         意思就是枚举上一组的所有字符,当出现在i组并且不是放到末尾,那么能-1
 6 */
 7 /************************************************
 8 * Author        :Running_Time
 9 * Created Time  :2015-8-7 11:08:46
10 * File Name     :UVA_11552.cpp
11  ************************************************/
12 
13 #include <cstdio>
14 #include <algorithm>
15 #include <iostream>
16 #include <sstream>
17 #include <cstring>
18 #include <cmath>
19 #include <string>
20 #include <vector>
21 #include <queue>
22 #include <deque>
23 #include <stack>
24 #include <list>
25 #include <map>
26 #include <set>
27 #include <bitset>
28 #include <cstdlib>
29 #include <ctime>
30 using namespace std;
31 
32 #define lson l, mid, rt << 1
33 #define rson mid + 1, r, rt << 1 | 1
34 typedef long long ll;
35 const int MAXN = 1e3 + 10;
36 const int INF = 0x3f3f3f3f;
37 const int MOD = 1e9 + 7;
38 char str[MAXN];
39 int dp[MAXN][MAXN];
40 bool vis[130];
41 
42 int main(void)    {     //UVA 11552 Fewest Flop
43     int T;  scanf ("%d", &T);
44     while (T--) {
45         int k;  scanf ("%d%s", &k, str + 1);
46         int len = strlen (str + 1);
47         memset (dp, INF, sizeof (dp));
48         for (int i=1; i<=len/k; ++i)    {
49             memset (vis, false, sizeof (vis));
50             for (int j=(i-1)*k+1; j<=i*k; ++j)  {
51                 vis[str[j]] = true;
52             }
53             int chunk = 0;
54             for (int j='a'; j<='z'; ++j)    {
55                 if (vis[j])    chunk++;
56             }
57             if (i == 1) {
58                 for (int j=1; j<=k; ++j)    {
59                     dp[i][j] = chunk;
60                 }
61                 continue;
62             }
63             for (int j=1; j<=k; ++j)    {
64                 int last = (i - 1) * k + j;
65                 for (int l=1; l<=k; ++l)    {
66                     int pre = (i - 2) * k + l;
67                     if (vis[str[pre]] && (chunk == 1 || str[pre] != str[last]))  {
68                         dp[i][j] = min (dp[i][j], dp[i-1][l] + chunk - 1);
69                     }
70                     else    dp[i][j] = min (dp[i][j], dp[i-1][l] + chunk);
71                 }
72             }
73         }
74 
75         int ans = INF;
76         for (int i=1; i<=k; ++i)    {
77             ans = min (ans, dp[len/k][i]);
78         }
79         printf ("%d\n", ans);
80     }
81 
82     return 0;
83 }

 

转载于:https://www.cnblogs.com/Running-Time/p/4711104.html

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

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

相关文章

多表联合查询

关联数据库字典表的多表联合查询 inner join…on 自动连接 需要用到表的所有信息时&#xff0c;可以用以下两种方法 1) left join…on… 左连接 &#xff08;以左为准&#xff0c;右边没有NULL代替&#xff09; 2) right join…on… 右连接&#xff08;以右为准&#xff…

python elasticsearch update_使用python的elasticsearch部分更新

我有以下格式的elasticsearch文档。我需要部分更新“x”字段并在其中添加python dict。{"_index": "gdata34","_type": "gdat","_id": "328091-72341-118","_version": 1,"_score": 1,"…

32位与64位注册表

如果32位系统OFP的注册表路径是 HKEY_LOCAL_MACHINE\SOFTWARE\Bohemia Interactive\ 那么在64系统里就应该是 HKEY_LOCAL_MACHINE\SOFTWARE\Wow6432Node\Bohemia Interactive\ 多了一级Wow6432Node转载于:https://www.cnblogs.com/zhang-pengcheng/p/4712135.html

http 请求头和响应头

客户端发送请求过程带着的数据&#xff1a; 1.请求地址 2.请求方式 3.请求头 request headers 4.请求参数 https://www.juhe.cn/ 130.... 1a2b....pei 服务端响应给客户端的信息&#xff1a; 1.响应内容 2.响应报文/响应头部 response headers a 响应头 b 响应体 3.http状…

[算法]-排序算法之希尔排序

希尔排序算法思想 希尔排序的实质就是分组插入排序&#xff0c;该方法又称缩小增量排序.基本思想是&#xff1a;先将整个待排元素序列分割成若干个子序列&#xff08;由相隔某个“增量”的元素组成的&#xff09;分别进行直接插入排序&#xff0c;然后依次缩减增量再进行排序&a…

python tkinter button颜色变不了_tkinter多按钮颜色变化

我使用tkinter创建一个8x8按钮矩阵&#xff0c;当按下单个按钮时&#xff0c;它会添加到最终列表中(例如finalList((0,0)&#xff0c;(5,7)&#xff0c;(6,6)&#xff0c;…)&#xff0c;允许我快速创建8x8(x&#xff0c;y)坐标图像。我已经创建了一个带有按钮的窗口&#xff0…

应用spss可靠性分析软件

问卷调查的可靠性分析 一、概念&#xff1a; 信度是指依据測验工具所得到的结果的一致性或稳定性&#xff0c;反映被測特征真实程度的指标。一般而言&#xff0c;两次或两个測验的结果愈是一致。则误差愈小&#xff0c;所得的信度愈高&#xff0c;它具有下面特性&#xff1a;1、…

springmvc中的单例问题

1&#xff0c;springmvc实际上是基于一个叫做DispatcherServlet的servlet的。servlet按照以往的学习经验&#xff0c;他是单事例多线程的。 Servlet生命周期 1.装载Servlet。这项操作一般是动态执行的。然而&#xff0c;Server通常会提供一个管理的选项&#xff0c;用于在Serve…

设计模式 -- 亨元模式(FlyWeight Pattern)

用来尽可能减少内存使用量&#xff0c;适用于存在大量重复对象的场景&#xff0c;达到对象共享&#xff0c;避免创建过多对象的效果&#xff0c;提升性能&#xff0c;避免内存溢出。 定义&#xff1a; 使用共享对象有效支持大量细粒度对象。 适用场景&#xff1a; 系统中存在大…

python3.6使用mysql_Python之——Python3.6连接MySQL

只安装了Python是不能连接数据库的&#xff0c;还要安装Python连接MySQL的相关类库&#xff0c;Python2.7连接MySQL的类库很多&#xff0c;MySQL官方最新支持的Python为Python3.4.&#xff0c;如下图所示&#xff1a;那么&#xff0c;在Python3.6上如何实现连接MySQL的功能呢&a…

android解析json

android2.3提供的json解析类 android的json解析部分都在包org.json下&#xff0c;主要有以下几个类&#xff1a; JSONObject&#xff1a;可以看作是一个json对象 JSONStringer&#xff1a;json文本构建类 JSONArray&#xff1a;可以看作是json的数组 JSONTokener&#xff1a;js…

MVVM模式于MVP模式

MVC、MVP、MVVM这些模式是为了解决开发过程中的实际问题而提出来的&#xff0c;目前作为主流的几种架构模式而被广泛使用。 一.MVP模式(Model-View-Presenter):传统的开发是MVP模式(例如jquery) MVP是把MVC中的Controller换成了Presenter&#xff08;呈现&#xff09;&#xff…

HUNAN 11560 Yangyang loves AC(二分+贪心)

http://acm.hunnu.edu.cn/online/?actionproblem&typeshow&id11560&courseid0 题意&#xff1a;总共有n天,每天yangyang都需要一个快乐值,有m个队友,每个队友都会给阳阳一个快乐值(为2的幂),并且只能给一次,如果某一天队友给的快乐值达到yangyang需要的快乐值那么…

BrowserSync开发利器

2019独角兽企业重金招聘Python工程师标准>>> 大大节省开发时间。安装使用简单。使用步骤&#xff1a; 1、nodejs环境 安装 2、在项目中使用npm安装到本项目 3、对要监听的文件执行响应命令 官网更详细&#xff1a;http://www.browsersync.cn/#install 原理&#xf…

python字符串解析_Python-字符串解析-正则-re

正则表达式特殊字符序列&#xff0c;匹配检索和替换文本普通字符 特殊字符 数量&#xff0c;普通字符用来定边界更改字符思路字符串函数 > 正则 > for循环元字符  匹配一个字符# 元字符大写&#xff0c;一般都是取小写的反1. 0~9 整数          \d    …

algorithm -- 选择排序

选择排序是《导论》第一章课后习题&#xff0c;仿照插入排序&#xff0c;再次运用循环不变式来证明下算法的正确性&#xff0c;C 源码&#xff1a; // 交换函数 void swap( int& a, int& b ) {a a^b;b a^b;a a^b; } void selectSort( int *arr, int count ) {if( a…

OD 完美走位

题目描述&#xff1a; 在第一人称射击游戏中&#xff0c;玩家通过键盘的A、S、D、W四个按键控制游戏人物分别向左、向后、向右、向前进行移动&#xff0c;从而完成走位。假设玩家每按动一次键盘&#xff0c;游戏人物会向某个方向移动一步&#xff0c;如果玩家在操作一定次数的键…

layui upload 后台获取不到值

后台获取不到值方法一&#xff1a; <script>layui.use(upload, function () {var upload layui.upload;//执行实例var uploadInst upload.render({elem: #test1 //绑定元素, url: /Home/UploadFiles //上传接口, field: "fileNames" //添加这个属性与后台…

ueeditor无法上传图片_百度ue文本编辑器开发中无法上传图片

第一次发文&#xff0c;好紧张呀&#xff0c;不知道会不会没人看。之前用ue遇到了一些坑&#xff0c;没人看就当自己记录了笔记。第一次用&#xff0c;总是会遇到问题&#xff0c;可以先查看下百度ue的演示http://ueditor.baidu.com/website/onlinedemo.html和API http://fex.b…

SQL 语句优化--IN语句优化案例

为什么80%的码农都做不了架构师&#xff1f;>>> 今天客户系统升级&#xff0c;通过DMVs性能分析查了一下&#xff0c;升级后发现一个语句执行时间比较长&#xff0c;执行语句要好几秒钟&#xff0c;调出语句如下&#xff1a; select distinct field003 from ufi2j0…