美团点评CodeM编程大赛-题一

来源:互联网 发布:mysql正在载入 编辑:程序博客网 时间:2024/06/11 20:46

美团点评CodeM编程大赛-题一

  • 题目描述

    美团外卖的品牌代言人袋鼠先生最近正在进行音乐研究。他有两段音频,每段音频是一个表示音高的序列。现在袋鼠先生想要在第二段音频中找出与第一段音频最相近的部分。
    具体地说,就是在第二段音频中找到一个长度和第一段音频相等且是连续的子序列,使得它们的 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

  • 语言

    JAVA JDK1.7

  • 代码
import java.util.Scanner;public class Main {    public static void main(String[] args) {        Scanner sc = new Scanner(System.in);        //第一段音频长度        int n = sc.nextInt();        int [] musicOne = new int [n];        //第一段音频音高        for(int i = 0; i < n; i++){            musicOne[i]= sc.nextInt();        }        //第二段音频长度        int m = sc.nextInt();        int[] musicTwo=new int [m];        //第二段音频音高        for(int i = 0; i < m; i++){            musicTwo[i]= sc.nextInt();        }        Long minDifference=Long.MAX_VALUE;        for (int i=0;i<m-n;i++){            Long sum=0L;            for (int j=0;j<n;j++){                sum+= (musicTwo[i+j]-musicOne[j])*(musicTwo[i+j]-musicOne[j]);            }            if (sum<minDifference){                minDifference=sum;            }        }        System.out.println(minDifference);    }}`

注:这里只做了简单的实现,具体的时间优化,内存优化还未考虑。

原创粉丝点击