蓝桥杯最大比例java实现

2024-06-08 20:48
文章标签 java 实现 最大 蓝桥 比例

本文主要是介绍蓝桥杯最大比例java实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最大比例

X星球的某个大奖赛设了M级奖励。每个级别的奖金是一个正整数。
并且,相邻的两个级别间的比例是个固定值。
也就是说:所有级别的奖金数构成了一个等比数列。比如:
16,24,36,54
其等比值为:3/2

现在,我们随机调查了一些获奖者的奖金数。
请你据此推算可能的最大的等比值。

输入格式:
第一行为数字N(N < 100),表示接下的一行包含N个正整数
第二行N个正整数Xi(Xi<1 000 000 000 000),用空格分开。每个整数表示调查到的某人的奖金数额

要求输出:
一个形如A/B的分数,要求A、B互质。表示可能的最大比例系数

测试数据保证了输入格式正确,并且最大比例是存在的。

例如,输入:
3
1250 200 32

程序应该输出:
25/4

再例如,输入:
4
3125 32 32 200

程序应该输出:
5/2

再例如,输入:
3
549755813888 524288 2

程序应该输出:
4/1

资源约定:
峰值内存消耗 < 256M

CPU消耗  < 3000ms


需要知识:

1.辗转相除法:

static long gcd(long a, long b) {return b == 0 ? a : gcd(b, a%b);}

2.更相减损法:


static long check(long a, long b) {while (a != b) {// 保证 a > bif (a < b) {long temp = a;a = b;b = temp;}long temp = a / b;a = b;b = temp;}return a;}

以上两个算法都是求两个数的最大公因数,一个用除法求,一个用减法求。
补充:等比数列是等比相等

题目思路:
先把输入的数用优先队列存,或者排序,目的是把数按 由小到大 的顺序处理。
依次处理队列中两个相邻的数 a1 a2,a2 a3, a3 a4......
假设最大比例系数为 b ,则 a2 / a1 = b^n1,a3 / a2 = b^n2, a4 / a3 = b^n3......。
要求的是 等比数列 中的最大比例系数,
若 n1 n2 n3 n4......的最大公因数为n,则解最大比例系数为 b^n 。

那么怎么求出 b^n 呢?
此时 b 未知,n1 n2 n3....也为未知,
但是 已知 b^n1 b^n2 b^n3...,且他们有相同的底数,则 b^n2 / b^n1 = b^(n2-n1)
所以可以通过 更相减损法 两两求 b^n1 b^n2, b^n2 b^n3...中最大公因数 n 时的 b^n。

例如: 2^4 = 16 2^6 = 64
2^6 / 2^4 = 2^2 -> 6 - 4 = 2
2^4 / 2^2 = 2^2 -> 4 - 2 = 2(减数和差相等,结束)
结果为 2^2 = 4。


完整代码:
package test;import java.util.*;/*** LQ 最大比例* Created by jingtao on 2017/2/20.*/
public class Main {// 辗转相除static long gcd(long a, long b) {return b == 0 ? a : gcd(b, a%b);}// 相减static long check(long a, long b) {while (a != b) {// 保证 a > bif (a < b) {long temp = a;a = b;b = temp;}long temp = a / b;a = b;b = temp;}return a;}static long[] arr;public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();arr = new long[n];Queue<Long> queue = new PriorityQueue<>((o1,o2) -> o1 > o2 ? 1 : -1);for (int i = 0; i < n; i++) {queue.add(scanner.nextLong());}long a = 1, b = 1; // 分别保存分子,分母boolean first = true;long left = queue.poll();while (!queue.isEmpty()) {long right = queue.poll();// 输入会有相等的数,所以队列中两数相等时跳过if (left != right) {// 后一个数除前一个数,并进行约分long temp = gcd(right, left);long nexta = right / temp;long nextb = left / temp;if (first) {a = nexta;b = nextb;left = right;first = false;continue;}a = check(a, nexta);b = check(b, nextb);}// 向右滑动队列left = right;}System.out.println(a + "/" + b);}
}



这篇关于蓝桥杯最大比例java实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043274

相关文章

SpringBoot3实现Gzip压缩优化的技术指南

《SpringBoot3实现Gzip压缩优化的技术指南》随着Web应用的用户量和数据量增加,网络带宽和页面加载速度逐渐成为瓶颈,为了减少数据传输量,提高用户体验,我们可以使用Gzip压缩HTTP响应,... 目录1、简述2、配置2.1 添加依赖2.2 配置 Gzip 压缩3、服务端应用4、前端应用4.1 N

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Python FastAPI+Celery+RabbitMQ实现分布式图片水印处理系统

《PythonFastAPI+Celery+RabbitMQ实现分布式图片水印处理系统》这篇文章主要为大家详细介绍了PythonFastAPI如何结合Celery以及RabbitMQ实现简单的分布式... 实现思路FastAPI 服务器Celery 任务队列RabbitMQ 作为消息代理定时任务处理完整

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法