日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

算法笔记_163:算法提高 最大乘积(Java)

發(fā)布時間:2023/12/2 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 算法笔记_163:算法提高 最大乘积(Java) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

目錄

1 問題描述

2 解決方案

?


1 問題描述

問題描述   對于n個數(shù),從中取出m個數(shù),如何取使得這m個數(shù)的乘積最大呢? 輸入格式   第一行一個數(shù)表示數(shù)據(jù)組數(shù)
  每組輸入數(shù)據(jù)共2行:
  第1行給出總共的數(shù)字的個數(shù)n和要取的數(shù)的個數(shù)m,1<=n<=m<=15,
  第2行依次給出這n個數(shù),其中每個數(shù)字的范圍滿足:a[i]的絕對值小于等于4。 輸出格式   每組數(shù)據(jù)輸出1行,為最大的乘積。 樣例輸入 1
5 5
1 2 3 4 2 樣例輸出 48

?

?


2 解決方案

?

具體代碼如下:

import java.util.ArrayList; import java.util.Collections; import java.util.Scanner;public class Main {public static long n, m, temp;public static ArrayList<Long> list = new ArrayList<Long>();//存放輸入的數(shù)public static ArrayList<Long> result = new ArrayList<Long>();public void getResult() {Collections.sort(list);for(int i = 0, j = list.size() - 1;m > 0;) {if(m >= 2) {long a1 = list.get(i) * list.get(i + 1);long a2 = list.get(j) * list.get(j - 1);if(a2 > a1) {temp *= list.get(j);j--;m--;} else {temp *= a1;i = i + 2;m = m - 2;} } else {if(m == 1) {temp *= list.get(j);j--;m--;}}}result.add(temp);}public static void main(String[] args) {Main test = new Main();Scanner in = new Scanner(System.in);int t = in.nextInt();while(t > 0) {t--;n = in.nextLong();m = in.nextLong();temp = 1;list.clear();for(int i = 0;i < n;i++) {long a = in.nextLong();list.add(a);}test.getResult();}for(int i = 0;i < result.size();i++)System.out.println(result.get(i));} }

?

?

?

?

?

參考資料:

???1.?藍(lán)橋杯 算法提高 最大乘積

?

轉(zhuǎn)載于:https://www.cnblogs.com/liuzhen1995/p/6786053.html

總結(jié)

以上是生活随笔為你收集整理的算法笔记_163:算法提高 最大乘积(Java)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。