一维消消乐 java_消消乐_vivo笔试题_牛客网

// 参照中大老哥思路做的

import java.io.*;

/**

* Welcome to vivo !

*/

public class Main {

public static void main(String[] args) throws Exception {

BufferedReader br = new BufferedReader(new InputStreamReader(System.in));

String inputStr = br.readLine();

int input[] = parseInts(inputStr.split(" "));

int output = solution(input);

System.out.println(output);

}

private static int[] parseInts(String[] strArr) {

if (strArr == null || strArr.length == 0) {

return new int[0];

}

int[] intArr = new int[strArr.length];

for (int i = 0; i 

intArr[i] = Integer.parseInt(strArr[i]);

}

return intArr;

}

private static int solution(int[] input) {

// TODO Write your code here

if(input == null || input.length == 0){

return 0;

}

int len = input.length;

return DFS(input, len);

}

public static int DFS(int[] arr, int len){

if(len == 1){

return 1;

}

if(len == 2){

if(arr[0] == arr[1]){

return 4;

}else{

return 2;

}

}

int max = 0;

int L = 0;

for(int i = 1; i 

if(arr[i] != arr[L]){

int[] copy = new int[len - (i - L)];

int j = 0;

for(; j 

copy[j] = arr[j];

}

for(int r = i; r 

copy[j++] = arr[r];

}

max = Math.max(max, DFS(copy, copy.length) + (i - L)*(i - L));

L = i;

}

}

if(L == 0){

return len * len;

}

int[] copy = new int[L];

for(int j = 0; j 

copy[j] = arr[j];

}

max = Math.max(max, DFS(copy, copy.length) + (len - L) * (len - L));

return max;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值