P8013 [COCI2013-2014#4] GMO 题解
题目大意
给定一字符串,你需要在这个字符串中插入若干个字符,使字符串中包含目标字符串,并使花费的代价最少。
思路
由于这道题数据范围不是很大,
代码
#include<bits/stdc++.h>
using namespace std;
int a[26],mn=2147483647;//将最小值初始化为最大
string s1,s2;
int main(){
cin>>s1>>s2;
cin>>a[0]>>a[2]>>a['G'-65]>>a['T'-65];
for(i=0;i<s1.size();i++){
int j=0,k=i,s=0; //指针,花费初始化
while(j<s2.size()){
if(s1[k]==s2[j])k++; //字母相同,原字符串指针后移
else s+=a[s2[j]-65]; //字母不同,更新花费
j++; //目标字符串指针后移
}
mn=min(mn,s); //更新最小值
}
cout<<mn;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器