关注
复习一下,防止复试被问到
class Solution {
public:
int findRotateSteps(string ring, string key) {
int m = key.size(), n = ring.size();
vector<vector<int>> pos(26, vector<int>(0, 0));
for (int i = 0; i < n; i++) {
pos[ring[i] - 'a'].push_back(i);
}
vector<vector<int>> dp(m, vector<int>(n, 0x3f3f3f3f));
for (auto j:pos[key[0] - 'a']) {
dp[0][j] = min(j, n - j);
}
for (int i = 1; i < m; i++) {
for (auto j:pos[key[i] - 'a']) {
for (auto k:pos[key[i - 1] - 'a']) {
dp[i][j] = min(dp[i][j], dp[i - 1][k] + min(abs(k - j), n - abs(k - j)));
}
}
}
int min = INT_MAX;
for (auto item:dp[m - 1]) {
if (item < min) {
min = item;
}
}
return min + m;
}
};
查看原帖
1 评论
相关推荐
点赞 评论 收藏
分享
牛客热帖
更多
正在热议
更多
# 上班以后,你还有哪些坚持的爱好? #
3430次浏览 100人参与
# 拼多多工作体验 #
42607次浏览 275人参与
# 你最近因为什么迷茫? #
20927次浏览 289人参与
# 你有哪些缓解焦虑的方法? #
47450次浏览 892人参与
# 你都在哪些场所面过试? #
8618次浏览 137人参与
# 记录实习开销 #
176678次浏览 677人参与
# 当你面对裁员会如何? #
355881次浏览 2878人参与
# 你认为小厂实习有用吗? #
114878次浏览 677人参与
# 实习离职怎么跟领导说 #
74751次浏览 412人参与
# 工作一周年分享 #
49238次浏览 243人参与
# AI coding的好用工具分享 #
8559次浏览 193人参与
# 工作压力大怎么缓解 #
133413次浏览 1163人参与
# 实习怎么做才有更好的产出 #
5418次浏览 128人参与
# 一起聊字节 #
241350次浏览 1018人参与
# 实习生工资多少才算正常? #
6764次浏览 128人参与
# 找工作以来,你最看不惯__ #
5217次浏览 136人参与
# 你给AI提过哪些离谱的需求? #
3022次浏览 106人参与
# 26届秋招投递记录 #
112216次浏览 661人参与
# 领导做过最不靠谱的事 #
7005次浏览 131人参与
# 上班到公司第一件事做什么? #
134380次浏览 938人参与
查看1道真题和解析