算法-按照要求保留数组元素使得和最大Java

在这里插入图片描述
分析:

  1. sum=0
  2. 取数组最大的数max
  3. sum+=max
  4. 删除数组最大元素max和值为max-1的数
  5. 继续步骤2,直到数组空了
    直接思路:删除用标志-1来表示
import java.util.Scanner;

public class SumMax {
	//查找最大元素下标
	 public static int selectTheMax(int[] num){
         int max = -1;
         int pos = -1;
         for(int i=0;i<num.length;i++){
             if(num[i] > max){
                 max = num[i];
                 pos = i;
             }
         }
         return pos;
     }
	//将值为max-1的数变成-1,即删除它
     public static void handle(int[] num,int maxpos){
         int maxnum = num[maxpos];
         for(int i=0;i<num.length;i ++){
             if(num[i] == maxnum-1){
                 num[i] = -1;
                 break;
             }
         }
     }

     public static void main(String[] args) {
         Scanner sc = new Scanner(System.in);
         int N = sc.nextInt();
         while(N-- > 0){
             int count = sc.nextInt();
             int num[] = new int[count];
             for(int l=0;l<count;l++) {
            	 num[l]=sc.nextInt();
             }
             int sum = 0;
             int i = 0;
             while(i < count){
                 int temp = selectTheMax(num);
                 if(temp == -1){//数组空了
                     break;
                 }
                 if(num[temp] != -1){
                     sum += num[temp];
                     handle(num,temp);
                     num[temp] = -1;//max变成-1
                     i++;
                 }else{
                     break;
                 }
             }
             System.out.println(sum);
         }
         sc.close();
     }

}

更简便的思路,用优先级队列(从大到小),每次取队头元素,然后比队头元素小1的数出队列,直到队列为空。

import java.util.Comparator;
import java.util.PriorityQueue;
import java.util.Queue;
import java.util.Scanner;

public class SumMax2 {
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int N = sc.nextInt();
		while (N-- > 0) {
			int count = sc.nextInt();
			int num[] = new int[count];
			int max = -1;
			Queue<Integer> queue = new PriorityQueue<Integer>(new Comparator<Integer>() {
				@Override
				public int compare(Integer o1, Integer o2) {
					return o2 - o1;//从大到小
				}
			});
			for (int l = 0; l < count; l++) {
				num[l] = sc.nextInt();
				queue.add(num[l]);
				if (max < num[l])
					max = num[l];
			}
			int sum = 0;
			while (!queue.isEmpty()) {
				int t = queue.poll();
				sum += t;
				while (!queue.isEmpty()&&queue.peek() == t - 1) {
					queue.poll();
				}
			}
			System.out.println(sum);
		}
		sc.close();
	}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学无止境jl

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值