博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA算法:旋转函数(Rotate Function)JAVA版本
阅读量:4039 次
发布时间:2019-05-24

本文共 1392 字,大约阅读时间需要 4 分钟。

JAVA算法:旋转函数(Rotate Function)JAVA版本

给定一个长度为 n 的整数数组 A 。

假设 Bk 是数组 A 顺时针旋转 k 个位置后的数组,我们定义 A 的“旋转函数” F 为:

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

计算F(0), F(1), ..., F(n-1)中的最大值。

注意:

可以认为 n 的值小于 105。

示例:

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

所以 F(0), F(1), F(2), F(3) 中的最大值是 F(3) = 26 。


算法设计

package com.bean.algorithm.basic;public class RotateFunction {	public static int maxRotateFunction(int[] A)     {        if(A.length == 0)            return 0;                int sum = 0;        for(int i = 0; i < A.length; ++i)            sum += A[i];                // Base case        int prev = 0;        for(int i = 0; i < A.length; ++i)            prev += i * A[i];                int max = Math.max(Integer.MIN_VALUE, prev);        for(int i = 1; i < A.length; ++i)        {            int curr = prev + sum - A.length * A[A.length - i];            max = Math.max(max, curr);                        prev = curr;        }                return max;    }		public static void main(String[] args) {		int[] array=new int[] {4, 3, 2, 6};		int ANSWER = maxRotateFunction(array);		System.out.println("ANSWER = "+ANSWER);			}}

程序运行结果:

ANSWER = 26

转载地址:http://sitdi.baihongyu.com/

你可能感兴趣的文章
[今日关注]鼓吹“互联网泡沫,到底为了什么”
查看>>
[互联网学习]如何提高网站的GooglePR值
查看>>
[关注大学生]求职不可不知——怎样的大学生不受欢迎
查看>>
[关注大学生]读“贫困大学生的自白”
查看>>
[互联网关注]李开复教大学生回答如何学好编程
查看>>
[关注大学生]李开复给中国计算机系大学生的7点建议
查看>>
[关注大学生]大学毕业生择业:是当"鸡头"还是"凤尾"?
查看>>
[茶余饭后]10大毕业生必听得歌曲
查看>>
gdb调试命令的三种调试方式和简单命令介绍
查看>>
C++程序员的几种境界
查看>>
VC++ MFC SQL ADO数据库访问技术使用的基本步骤及方法
查看>>
VUE-Vue.js之$refs,父组件访问、修改子组件中 的数据
查看>>
Vue-子组件改变父级组件的信息
查看>>
Python自动化之pytest常用插件
查看>>
Python自动化之pytest框架使用详解
查看>>
【正则表达式】以个人的理解帮助大家认识正则表达式
查看>>
性能调优之iostat命令详解
查看>>
性能调优之iftop命令详解
查看>>
非关系型数据库(nosql)介绍
查看>>
移动端自动化测试-Windows-Android-Appium环境搭建
查看>>