Given an array of integers A and let n to be its length.

Assume Bk to be an array obtained by rotating the array A k positions clock-wise, we define a "rotation function" F on A as follow:

F(k) = 0 * Bk[0] + 1 * Bk[1] + ... + (n-1) * Bk[n-1].

Calculate the maximum value of F(0), F(1), ..., F(n-1).

Note:
n is guaranteed to be less than 105. Example: A = [4, 3, 2, 6] F(0) = (0 * 4) + (1 * 3) + (2 * 2) + (3 * 6) = 0 + 3 + 4 + 18 = 25
F(1) = (0 * 6) + (1 * 4) + (2 * 3) + (3 * 2) = 0 + 4 + 6 + 6 = 16
F(2) = (0 * 2) + (1 * 6) + (2 * 4) + (3 * 3) = 0 + 6 + 8 + 9 = 23
F(3) = (0 * 3) + (1 * 2) + (2 * 6) + (3 * 4) = 0 + 2 + 12 + 12 = 26 So the maximum value of F(0), F(1), F(2), F(3) is F(3) = 26.

F(0) = (0 * 4) + (1 * 3) + (2 * 2) + (3 * 6) = 0 + 3 + 4 + 18 = 25    [4, 3, 2, 6]

F(1) = (0 * 6) + (1 * 4) + (2 * 3) + (3 * 2) = 0 + 4 + 6 + 6 = 16      [6, 4, 3, 2]        diff = (4+3+2) - 6*(nums.length-1)

F(2) = (0 * 2) + (1 * 6) + (2 * 4) + (3 * 3) = 0 + 6 + 8 + 9 = 23          [2, 6, 4, 3]    diff = (6+4+3) - 2*(nums.length-1)

 public class Solution {
public int maxRotateFunction(int[] A) {
if (A==null || A.length==0) return 0;
int value = 0;
int sum = 0;
int maxValue = Integer.MIN_VALUE; for (int i=0; i<A.length; i++) {
value += i * A[i];
sum += A[i];
} for (int j=A.length-1; j>=0; j--) {
value = value + (sum-A[j])-A[j]*(A.length-1);
maxValue = Math.max(maxValue, value);
}
return maxValue;
}
}

最新文章

  1. 十分钟了解分布式计算:Spark
  2. RabbitMQ的安装
  3. Python学习笔记07
  4. Microsoft Enterprise Library 5.0 缓存配置
  5. magento安装新插件后后台配置空白解决办法
  6. java第二课:运算符和表达式
  7. java版-JQuery上传插件Uploadify使用实例
  8. 重新想象 Windows 8 Store Apps (33) - 关联启动: 使用外部程序打开一个文件或uri, 关联指定的文件类型或协议
  9. 转: js快速分享代码
  10. cmd alias 自定义命令
  11. LNMP的安装
  12. Python进阶之装饰器
  13. 【python】字符串
  14. LeetCode - 二叉树的最大深度
  15. [Poi2012]Festival 差分约束+tarjan
  16. [Swift]LeetCode561. 数组拆分 I | Array Partition I
  17. vue-cli的跨域配置(自己总结)
  18. bll
  19. POIUtils 读取 poi
  20. Nginx+Tomcat-cluster构建

热门文章

  1. LR处理文件上传和下载
  2. NRF51822之GPIOTE介绍
  3. docker gitlab,redmine,etc development enviroments
  4. Java实验报告二:Java面向对象程序设计
  5. Redis学习笔记(8)-发布/订阅
  6. Architecture of a Highly Scalable NIO-Based Server
  7. Android.mk学习 笔记
  8. QRadioButton
  9. MAC下配置ZSH
  10. H264关于RTP协议的实现