C. Lazy Narek (Codeforces Round 972 (Div. 2))

C. Lazy Narek

思路:

动态规划 dp

dp[i] 表示 目前寻找的字符下标为i 时的最大分数(<=i<=4)

从前往后遍历字符串,每个字符串找5次,找完后把dp取max

注意找的过程中不能修改原dp数组,因为这5次查找是并行的,期间用ndp保存分数,找完了再修改dp (被数组的复制引用坑麻了,debug了半天)

详见注释

代码:
cpp 复制代码
#include <bits/stdc++.h>
#define endl '\n'
#define int long long
#define pb push_back
#define pii pair<int,int>
const int MOD = 1e9 + 7;
const int INF = 0x3f3f3f3f;
typedef long long ll;
using namespace std;

void solve() {
	const string ss = "narek";
	string s[10005];
	int n, m;
	cin >> n >> m;
	for (int i = 0; i < n; i++) {
		cin >> s[i];
	}

	int dp[5] = {0, -INF, -INF, -INF, -INF};
	//dp初始化为很小的数, dp[0]要初始化为0,是没有选择任何字符串的情况
	for (int i = 0; i < n; i++) {
		int ndp[5];  //临时保存dp下一状态的值
		copy(dp, dp + 5, ndp);
		for (int j = 0; j < 5; j++) {
			int fs = dp[j];  //当前状态的分数
			int nc = j;  //当前在narek中的位置
			for (auto c : s[i]) {
				if (c == ss[nc]) {  //如果字符匹配
					nc++;
					if (nc == 5) {
						fs += 5;
						nc = 0;
					}
				} else if (ss.find(c) != -1) {  //不匹配
					fs--;
				}
			}
			ndp[nc] = max(ndp[nc], fs);
		}

		copy(ndp, ndp + 5, dp);

//		for(int i=0;i<5;i++)
//			cout<<"=dp["<<i<<"] = "<<dp[i]<<endl;
	}
	int ans = 0;
	for (int i = 0; i < 5; i++) {
		ans = max(ans, dp[i] - i); //这里减去i是为了减去最后查找中断的narek的分数
	}
	cout << ans << endl;
}

signed main() {
	cin.tie(0)->ios::sync_with_stdio(0);
	int T = 1;
	cin >> T;
	while (T--) {
		solve();
	}
	return 0;
}
相关推荐
ajassi200019 分钟前
开源 C++ QT Widget 开发(十五)多媒体--音频播放
linux·c++·qt·开源
焦耳加热1 小时前
阿德莱德大学Nat. Commun.:盐模板策略实现废弃塑料到单原子催化剂的高值转化,推动环境与能源催化应用
人工智能·算法·机器学习·能源·材料工程
wan5555cn1 小时前
多张图片生成视频模型技术深度解析
人工智能·笔记·深度学习·算法·音视频
u6061 小时前
常用排序算法核心知识点梳理
算法·排序
鹅毛在路上了3 小时前
C++, ffmpeg, libavcodec-RTSP拉流,opencv实时预览
c++·opencv·ffmpeg
John_ToDebug3 小时前
定制 ResourceBundle 的实现与 DuiLib 思想在 Chromium 架构下的应用解析
c++·chrome·ui
蒋星熠4 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
小欣加油4 小时前
leetcode 面试题01.02判定是否互为字符重排
数据结构·c++·算法·leetcode·职场和发展
3Cloudream4 小时前
LeetCode 003. 无重复字符的最长子串 - 滑动窗口与哈希表详解
算法·leetcode·字符串·双指针·滑动窗口·哈希表·中等
王璐WL4 小时前
【c++】c++第一课:命名空间
数据结构·c++·算法