| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> LeetCode 1464 - 1467 -> 正文阅读 |
|
[数据结构与算法]LeetCode 1464 - 1467 |
数组中两元素的最大乘积数据范围较小:500 两个下标不同 两重循环枚举 i 和 j,在所有的 i 和 j 对中找最大值,时间复杂度 O( n^2 )
切割后面积最大的蛋糕?数组给出了所有横、竖切的线的位置,在所有切开的蛋糕块中找面积最大值,即找横竖中相间最大的:把 0 和 宽、高 都放进对应的数组中,然后排序,再分别找横竖中间隔最大的相乘然后取余→ 注意要取余后返回,否则会因为整数溢出而报错 横向、纵向的线会把蛋糕分成若干部分 任取一个横向,再任取一个纵向,都会对应一个小方块,小方块的高度、宽度就是横向的高度、纵向的宽度,行、列是独立的,让整个面积最大相当于:在horizontalCuts 中拿一个数,在 verticalCuts 中拿一个数,使得乘积最大→ 找竖方向最大的数与横方向最大的数相乘就是答案→ 注意乘积可能超过 int 的范围需要对 10^9 + 7 取余 需要扫描水平的最大值和竖直的最大值,时间复杂度为 O( n ) 1??????? 1??????? 2??????? 1 1 2 1
重新规划路线给出一棵树,n 个点,编号是 0 ~ n - 1,树的边用二元组给出,每一个二元组表示 a 到 b 的有向边,让所有的游客都能走到城市 0,但是所有线都是有向的,如果想让所有游客都走到城市 0,需要将树中的某些边反向,问:最少需要反向多少条线? 示例1: 如果把所有边看成无向的,就是一棵树 希望让每一个点都可以走到 0,走的时候让逆向的边反向 问:变更方向的最小路线数?由于是一棵树,把它看成无向边,每个点到根节点的路径是唯一的,需要把所有需要反向边都改变,所有同向边都不能变,实际上答案是唯一的 只需要统计从每个点到根节点的路径中,哪些边需要反向,把要反向的边的数量求出来即可 遍历时可以从根节点开始向每一个节点遍历整棵树,例如,遍历的时候发现从 0→ 1不是从下往上,就把它反向,并记录 在题目中存储的是有向边,但是在写代码时,要先存成无向边,记录一个方向,因为如果是存的有向边,如果边是从下往上,就不能往下走,因此要存储无向边,但记录真实的方向 实际上就是把整棵树遍历一遍,时间复杂度为 O( n ) 由于不一定是二叉树,所以存储的时候用邻接表来存储,不仅要存编号,而且要存方向,用 pair 来存储
两个盒子中球的颜色数相同的概率? |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 7:42:01- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |