蓝桥杯--基础(哈夫曼)

复制代码
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Scanner;

public class BASIC28 {
    //哈夫曼书
    public  static void main(String[] args) {
        Scanner Scanner=new Scanner(System.in);
        int n=Scanner.nextInt();
        List<Integer> list=new ArrayList<Integer>() ;
        for(int i=0;i<n;i++)
        {
            list.add(Scanner.nextInt());
        }
        //数组删除一个元素比较的麻烦(使用java里面的数组不能直接的删除一个元素)
        //但是使用list就是可以直接的进行删除了是吗???
        //原来使用list是可以直接的进行排序的
        int sum=0;
        while(list.size()!=1)
        {
            Collections.sort(list);
            //要输出的是每次相加的这个和是吧,那么需要另外的开辟一个来进行存储???
            list.add(list.get(0)+list.get(1));
            sum+=list.get(0)+list.get(1);
            //当把第一个元素删除之后,原本的第二个元素就是变为了第一个元素
            //所以这个地方需要进行删除还是0
            list.remove(0);
            list.remove(0);

        }
        //最后一个数字就是计算得到的,已经在前面的基础上添加过了
        System.out.println(sum);
    }
}

根据可能的规则,直接使用list进行存储(因为提供直接移除元素的函数)

然后需要注意的就是list也是可以排序的,不过是Collections.sort()

然后数组的排序是Arrays.sort() 进行排序

最后就是在移除的时候,应该移除的是前面的两个最小的

但是当移除一个之后,后面的那个又会接着补充进来,所以这个时候就是这个样子的

相关推荐
测试老哥3 小时前
2026最新的软件测试面试八股文(答案+文档)
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
jiaozi_zzq6 小时前
2026 高职大数据管理与应用专业就业方向有哪些
大数据·职场和发展·数据分析·证书
ada7_6 小时前
LeetCode(python)39.组合总和
开发语言·数据结构·python·算法·leetcode·职场和发展
sprintzer7 小时前
12.26-1.5力扣字符串刷题
算法·leetcode·职场和发展
Croa-vo8 小时前
TikTok 系统设计 VO 面经:实时热门视频检测系统深度复盘(附求职助攻指南)
java·算法·leetcode·面试·职场和发展
Swift社区8 小时前
LeetCode 466 统计重复个数
算法·leetcode·职场和发展
不吃香菜5678 小时前
Java 后端开发面试中,人事(HR)环节的问题
java·面试·职场和发展
小周同学@8 小时前
js实现力扣第13题(罗马数字转整数)
javascript·算法·leetcode·职场和发展·哈希表
羑悻的小杀马特9 小时前
LeetCode 42接雨水全解:暴力超时→DP降维打击→双指针极限压缩空间→单调栈栈式凹槽定位,全景式解析算法优化路径
算法·leetcode·职场和发展·动态规划·双指针·单调栈·接雨水
西部驯兽师1 天前
NocoBase的开发技能
职场和发展