题目:
美团外卖的品牌代言人袋鼠先生最近正在进行音乐研究。他有两段音频,每段音频是一个表示音高的序列。现在袋鼠先生想要在第二段音频中找出与第一段音频最相近的部分。
具体地说,就是在第二段音频中找到一个长度和第一段音频相等且是连续的子序列,使得它们的 difference 最小。两段等长音频的 difference 定义为:
difference = SUM(a[i] - b[i])2 (1 ≤ i ≤ n),其中SUM()表示求和
其中 n 表示序列长度,a[i], b[i]分别表示两段音频的音高。现在袋鼠先生想要知道,difference的最小值是多少?数据保证第一段音频的长度小于等于第二段音频的长度。
输入描述:
- 第一行一个整数n(1 ≤ n ≤ 1000),表示第一段音频的长度。
- 第二行n个整数表示第一段音频的音高(0 ≤ 音高 ≤ 1000)。
- 第三行一个整数m(1 ≤ n ≤ m ≤ 1000),表示第二段音频的长度。
- 第四行m个整数表示第二段音频的音高(0 ≤ 音高 ≤ 1000)。
输出描述:
- 输出difference的最小值
输入例子:
2
1 2
4
3 1 2 4
输出例子:
0
#include <stdio.h>
#include <iostream>
using namespace std;
int cal_difference(int *a,int *b,int n)
{
int res=0;
for(int i=0;i<n;++i)
{
int dif=a[i]-b[i];
res = res + dif*dif;
}
return res;
}
int main()
{
int n=0,m=0;
scanf("%d",&n);
int *a=new int[n];
for(int i=0;i<n;++i)
scanf("%d",&a[i]);
scanf("%d",&m);
int *b=new int[m];
for(int i=0;i<m;++i)
scanf("%d",&b[i]);
if(n==m)
{
cout<<cal_difference(a,b,n)<<endl;
return 0;
}
int len=m-n;
int diff=0x7fffffff;
for(int i=0;i<=len;++i)
{
int tmp=cal_difference(a,b+i,n);
if(tmp<diff)
{
diff=tmp;
}
if(diff == 0)
{
break;
}
}
cout<<diff<<endl;
delete a;
delete b;
return 0;
}