개의 항을 가진 수열 이 있다. 수열의 인접한 항을 교환하는 작업을 최대 번 수행하여 의 값을 가장 크게 만들고 싶다.
번 이하의 작업으로 만들 수 있는 의 최댓값을 출력하는 프로그램을 작성하라.
첫 줄에 수열의 길이를 나타내는 정수 과 교환 작업의 최대 횟수를 나타내는 정수 가 주어진다. ( )
그다음 줄에 수열의 개의 항의 초깃값이 공백으로 구분되어 차례대로 주어진다. 이 값은 모두 이상 이하의 정수다.
첫 줄에 만들 수 있는 의 최댓값을 출력한다.
5 2 3 2 1 5 2
3
예제에서, 첫 번째와 두 번째의 과 를 교환하면 수열은 가 된다. 다시, 네 번째와 다섯 번째의 와 를 교환하면 수열은 가 된다. 이 경우가 을 가장 크게 만들 수 있는 방법이므로 답은 이다.
입력 케이스들은 다음과 같은 종류로 구별되며, 한 종류의 케이스를 다 맞혀야 그 종류에 배정된 점수를 받을 수 있다.
종류 1: 17점
종류 2: 11점
종류 3: 13점
종류 4: 31점
종류 5: 28점
모든 입력 케이스가 주어진다.