Ginger 有一个 n 朵花的大花环,但是花环没有颜色,所有 Ginger 请来了他的好朋友 m_rd 来给染颜色,但 Ginger 只能提供 k 种颜色,第 i 种颜色有一个花费 wi ,他想让你用最小的花费来给大花环染色,但 Ginger 还有一个条件,环上的连续三朵花不能是同一种颜色。
注意花环是环状结构。
输入描述:
第一行给定两个正整数 n,k (3≤n≤105,1≤k≤4) 表示花的个数和颜色个数。
第二行给定 k 个正整数 wi (1≤wi≤109) 表示每个颜色的花费。
输出描述:
输出最小花费,如果不能染色输出 Ginger666示例1
输入
5 4 1 2 3 4输出
7说明
样例 1 为 1+2+1+2+1=7
由于是环形,所以不能是 1+1+2+1+1=6
示例2
输入
3 1 1
输出
Ginger666
思路很多,不要被样例一迷惑,我的思路是三个分成一组,看有多少个三,这一组由两个花费最少的颜色和一个花费第二少的颜色组成,多出一个则加上一个花费第二少,如果多出两个加上一个 花费第一少和一个花费第二少.
#include <iostream>
#include <algorithm>
using namespace std;
long long n,k;
long long s[15];
int main(){
scanf("%lld%lld",&n,&k);
for(int i=1;i<=k;i++){
scanf("%lld",&s[i]);
}
sort(s+1,s+k+1);
if(k<=1){
printf("Ginger666");
return 0;
}
long long sss;
long long temp1=2*s[1]+s[2];
long long temp2=n/3;
long long temp3=n-temp2*3;
if(temp3==0){
sss=temp2*temp1;
}
if(temp3==1){
sss=temp2*temp1+s[2];
}
if(temp3==2){
sss=temp2*temp1+s[2]+s[1];
}
printf("%lld",sss);
return 0;
}