Codeforces Round #422 (Div. 2) B. Crossword solving

本文介绍了一个字符串匹配问题,目标是最小化两个字符串在匹配过程中的不匹配位置数量。通过遍历长字符串的所有可能起始位置并与短字符串进行比较,找到最佳匹配方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目大意

给出较短串s和较长串t,s可以对应在任何位置,最少有多少位置不匹配。

题解

暴力。。。。
(注意把边界去掉)

 #include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int read()
{
    char ch=getchar();int f=0;
    while(ch<'0'||ch>'9') ch=getchar();
    while(ch>='0'&&ch<='9')
    {f=(f<<1)+(f<<3)+ch-'0';
    ch=getchar();}
    return f;
}
char s[1005],t[1005];int ans=2000000000;
int main()
{
    int n=read(),m=read();
    scanf("%s%s",s+1,t+1);
    int temp=0,pla;
    for(int i=1;i<=m-n+1;i++)
    {
        temp=0;
        for(int j=1;j<=n;j++)
        {
            if(s[j]!=t[j+i-1])
            temp++;
        }
        //cout<<temp<<" ";
        if(temp<ans)
        {
            ans=temp;
            pla=i;
        }
    }
    printf("%d\n",ans);
    for(int i=1;i<=n;i++)
    {
        if(s[i]!=t[pla+i-1])
        printf("%d ",i);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值