当前位置: 首页 > article >正文

贪心算法习题其三【力扣】【算法学习day.20】

前言

###我做这类文档一个重要的目的还是给正在学习的大家提供方向(例如想要掌握基础用法,该刷哪些题?)我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!


习题

1.划分字母区间

题目链接:763. 划分字母区间 - 力扣(LeetCode)

题面:

代码:

class Solution {
    public List<Integer> partitionLabels(String s) {
        List<Integer> list = new ArrayList<>();
        char[] srr = s.toCharArray();
        int n = s.length();
         int[] addr = new int[30];
         for(int i = 0;i<n;i++){
            addr[srr[i]-'a'] = i;
         }
        int count = 0;
        int l = 0;
        int flag = 0;
        int flagl = 0;
        while(l<n){
            if(flag == 0){
                count++;
                flagl = addr[srr[l]-'a'];
                if(flagl==l){
                   list.add(1);
                   count=0;
                }
                flag=1;
            }else{
                flagl = Math.max(addr[srr[l]-'a'],flagl);
                count++;
                if(l==flagl){
                    list.add(count);
                    count = 0;
                    flag = 0;
                }
            }
             l++;
        }
        return list;
    }
}

2.合并区间

题目链接:56. 合并区间 - 力扣(LeetCode)

题面:

代码:

class Solution {
    public int[][] merge(int[][] intervals) {
        int n = intervals.length;
        int[][] ans = new int[n][2];
        Arrays.sort(intervals, new Comparator<int[]>() {
            @Override
            public int compare(int[] o1, int[] o2) {
                return o1[0] - o2[0];
            }
        });
        int xl = 0;
        int xr = 0;
        int flag = 0;
        int l = 0;
        int count = 0;
        while (l < n) {
            if (flag == 0) {
                if (l == n - 1) {
                    ans[count][0] =intervals[l][0];
                    ans[count++][1] =intervals[l][1];
                    l++;
                    break;
                }
                xl = intervals[l][0];
                xr = intervals[l][1];
                flag=1;
            }
            else{
                if((intervals[l][0]<=xr&&xr<=intervals[l][1])||(xr>=intervals[l][1]&&xl<=intervals[l][0])){
                    xr =Math.max(intervals[l][1],xr);
                    xl =Math.min(intervals[l][0],xl);
                    if(l==n-1){
                        ans[count][0] =xl;
                        ans[count++][1] = xr;
                        break;
                    }
                }
                else{
                    ans[count][0] =xl;
                    ans[count++][1] = xr;
                    l--;
                    flag = 0;
                }

            }
            l++;
        }
         int[][] ans2 = new int[count][2];
         for(int i = 0;i<count;i++){
            ans2[i]=ans[i];
         }
        return ans2;
    }
}

后言

上面是贪心算法的部分习题,下一篇会讲解贪心算法的其他相关力扣习题,希望有所帮助,一同进步,共勉!   


http://www.kler.cn/a/376795.html

相关文章:

  • Puppeteer点击系统:解锁百度流量点击率提升的解决案例
  • 【力扣专题栏】面试题 01.02. 判定是否互为字符重排,如何利用数组模拟哈希表解决两字符串互排问题?
  • Java实现动态切换ubuntu壁纸功能
  • 彻底理解链表(LinkedList)结构
  • 11.Three.js使用indexeddb前端缓存模型优化前端加载效率
  • C++——编写一程序,输人月份号,输出该月的英文月名。例如,输入3,则输出March,要求用指针数组处理。
  • angular登录按钮输入框监听
  • Python 定时调度任务
  • nignx代理获取真实地址request.getRequestURL()
  • el-select 的默认选中 以及后端返回的数据进行默认选中
  • Java多态特性的向上转型
  • SD-WAN分布式组网:构建高效、灵活的企业网络架构
  • 协议(OSI-tcp-udp)
  • linux 运行 activemq,Linux 安装 ActiveMQ 服务器详解
  • windows C#-泛型类型
  • Rust 力扣 - 1461. 检查一个字符串是否包含所有长度为 K 的二进制子串
  • 动态SQL在梧桐数据库的使用介绍
  • MySQL锁表快速解决办法
  • ELK的ElasticStack概念
  • 11408 计网===物理层
  • 使用 Redis 作为异步队列:原理、实现及最佳实践
  • 小新学习k8s第六天之pod详解
  • Linux 常用安装软件
  • 虚幻引擎5(UE5)学习教程
  • BERT语言模型详解【Encoder-Only】
  • LeetCode HOT100系列题解之课程表(9/100)