LeetCode第151场周赛(Java)
这是我第一次写周赛的题目,而且还是虚拟的。从这次起,以后就将所有错过的题目都写到博客来。当然既然是我错的,那代码肯定不是我自己的。我会注明来源。并且我会自己敲一遍。多总结总是没坏处的。
另外比较糟糕的是我错过了PAT的报名时间(截止到8/30 12:00),所以暂时我就不刷PAT的题目,专注于LeetCode的题目。
下面进入正题
1169. 查询无效交易
这题真滴不难,但是我当时想的非常复杂,我以为不会这么简单的就那么两个条件判断。。。谁曾想,真滴就是这样。。。
参考:uwi 这位大神的。
思路:
- 直接输入所有交易,将信息保存到四个数组中。
- 用一个标志数组保存交易是否无效,无效则为
true
。 - 两层循环检查交易是否冲突。
- 将无效的交易信息添加到
List<String> ans
中。
代码如下:
class Solution {
public List<String> invalidTransactions(String[] transactions) {
int length = transactions.length; // 交易个数
boolean[] invalid = new boolean[length]; // 可能无效
String[] name = new String[length]; // 交易名
int[] time = new int[length]; // 时间
int[] amount = new int[length]; // 金额
String[] city = new String[length]; // 城市
// 输入所有交易信息
for (int i = 0; i < length; ++i) {
String str = transactions[i];
String[] arr = str.split(",");
name[i] = arr[0];
time[i] = Integer.parseInt(arr[1]);
amount[i] = Integer.parseInt(arr[2]);
city[i] = arr[3];
}
// 检查每笔交易是否有效
for (int i = 0; i < length; ++i) {
if (amount[i] > 1000) { // 金额超过1000
invalid[i] = true; // 无效
}
// 检查后面的交易是否与第i笔交易冲突
for (int j = i + 1; j < length; ++j) {
if (name[i].equals(name[j]) && // 交易名相同
!city[i].equals(city[j]) && // 城市不同
Math.abs(time[i] - time[j]) <= 60) {// 时间差不超过60
invalid[i] = invalid[j] = true; // 这两笔交易都无效
}
}
}
// 将无效的交易添加到列表
List<String> ans = new ArrayList<String>();
for (int i = 0; i < length; ++i) {
if (invalid[i]) {
ans.add(transactions[i]);
}
}
return ans;
}
}
1172. 餐盘栈
大神 megaspazz 的原代码,我啥都没改(写的太好了,我不知道怎么改),他是拿的满分,但是我提交三次全超时,不试了,代码肯定是正确的。
第一次碰到 TreeSet
,看起来挺费劲的。所有地方都有注释。我不敢保证这次我都理解了。但是下次至少熟悉一些。这位博主写的还不错 Java集合类(四)—TreeSet - 简书。
class DinnerPlates {
TreeSet<Integer> pushable = new TreeSet<>();// 保存非满栈下标
TreeSet<Plate> plates = new TreeSet<>();// 保存盘子
int[] heights = new int[100001];// 每个栈的栈顶
int cap;// 栈的最大容量
public DinnerPlates(int capacity) {// 构造方法
for (int i = 0; i <= 100000; ++i) {// 最多100001个栈
pushable.add(i);// 非满栈按照序号依次排好
}
cap = capacity;
}
// 将给出的正整数val推入从左往右第一个没有满的栈。
public void push(int val) {
int whichStack = pushable.first();// 获取第一个非空栈下标。
// 创建一个盘子,参数分别是“所在的栈的下标”,“栈顶的下标”,“值”。
Plate p = new Plate(whichStack, heights[whichStack], val);
plates.add(p);// 将盘子添加到栈顶
++heights[whichStack];// 栈顶上移
if (heights[whichStack] == cap) {// 当前栈满
// 去掉满栈的下标,这样以后取第一个的时候始终得到一个非空栈
pushable.remove(whichStack);
}
}
// 返回从右往左第一个非空栈顶部的值,并将其从栈中删除;如果所有的栈都是空的,返回-1。
public int pop() {
// 返回从右往左第一个非空栈顶部的值,并将其从栈中删除
Plate p = plates.pollLast();
if (p == null) {// 如果是null,那么就说明所有的栈都是空的
return -1;// 返回-1
}
remove(p);// 将盘子从栈中删除
return p.value;// 返回取出的盘子所保存的值
}
// 返回编号index的栈顶部的值,并将其从栈中删除;如果编号index的栈是空的,返回-1。
public int popAtStack(int index) {
// 获取新创建的盘子的左边的非空的盘子,如果没有,返回null
Plate p = plates.lower(new Plate(index + 1, 0, 0));
// 如果为null,或者取出的不是我们要找的编号为index的栈中的盘子
if (p == null || p.index != index) {
return -1;// 说明编号index的栈是空的,返回-1
}
remove(p);// 如果找到了,将它从栈中删除
return p.value;// 返回盘子的值
}
// 将盘子p从栈中删除
private void remove(Plate p) {
plates.remove(p);
--heights[p.index];// 栈顶向下移一位
pushable.add(p.index);// 当前栈已经不是满栈
}
// 盘子,实现排序的Comparable接口
private static class Plate implements Comparable<Plate> {
public int index;// 所在的栈的下标
public int height;// 在栈中的下标
public int value;// 值
public Plate(int i, int h, int v) {
index = i;
height = h;
value = v;
}
@Override
public int compareTo(Plate p) {
// 保证每个栈是从左往右排好的
int di = Integer.compare(index, p.index);// 下标升序排序
if (di != 0) {
return di;
}
// 高度升序排序,保证栈顶元素始终在右边
return Integer.compare(height, p.height);
}
}
}
LeetCode第151场周赛(Java)的更多相关文章
- LeetCode 第 151 场周赛
一.查询无效交易(LeetCode-1169) 1.1 题目描述 1.2 解题思路 根据,它和另一个城市中同名的另一笔交易相隔不超过 60 分钟(包含 60 分钟整) 得出 城市A和其他城市任何一笔交 ...
- LeetCode 第 165 场周赛
LeetCode 第 165 场周赛 5275. 找出井字棋的获胜者 5276. 不浪费原料的汉堡制作方案 5277. 统计全为 1 的正方形子矩阵 5278. 分割回文串 III C 暴力做的,只能 ...
- Leetcode第 217 场周赛(思维量比较大)
Leetcode第 217 场周赛 比赛链接:点这里 做完前两题我就知道今天的竞赛我已经结束了 这场比赛思维量还是比较大的. 1673. 找出最具竞争力的子序列 题目 给你一个整数数组 nums 和一 ...
- LeetCode第152场周赛(Java)
这算是我第一次正式参加 LeetCode 的周赛吧.通过两道题.意料之中(通过上次模拟可以看出来).总的来说,脑袋还是不太灵光.想的有点慢.全球第一名 0:10:19 就全部通过...感觉我的智商被狠 ...
- LeetCode第154场周赛(Java)
估计要刷很久才能突破三道题了.还是刷的太少.尽管对了前两题,但是我觉得写的不怎么样.还是将所有题目都写一下吧. 5189. "气球" 的最大数量 题目比较简单.就是找出一个字符串中 ...
- Leetcode 第133场周赛解题报告
今天参加了leetcode的周赛,算法比赛,要求速度比较快.有思路就立马启动,不会纠结是否有更好的方法或代码可读性.只要在算法复杂度数量级内,基本上是怎么实现快速就怎么来了. 比赛时先看的第二题,一看 ...
- LeetCode 第 196 场周赛 (题目:5452-5455,这是参加过最坑的周赛,暴力n^2居然可以过)
5452. 判断能否形成等差数列 给你一个数字数组 arr . 如果一个数列中,任意相邻两项的差总等于同一个常数,那么这个数列就称为 等差数列 . 如果可以重新排列数组形成等差数列,请返回 tru ...
- Leetcode 第137场周赛解题报告
今天的比赛的题目相对来说比较「直白」,不像前几周都是一些特定的算法,如果你没学过不可能想出来. 做了这些周,对leetcode比赛的题目也发现了一些「规律」. 一般前两道题都很「简单」,只要有想法,直 ...
- LeetCode 第 153 场周赛
一.公交站间的距离(LeetCode-5181) 1.1 题目描述 1.2 解题思路 比较简单的一题,顺时针.逆时针两次遍历,就能解决. 1.3 解题代码 class Solution { publi ...
随机推荐
- Lightning Web Components 来自salesforce 的web 组件化解决方案
Lightning Web Components 是一个轻量,快速,企业级别的web 组件化解决方案,官方网站也提供了很全的文档 对于我们学习使用还是很方便的,同时我们也可以方便的学习了解salesf ...
- 数据分析师(Data Analyst),数据工程师(Data Engineer),数据科学家(Data Scientist)的区别
数据分析师(Data Analyst):负责从数据中提取出有用的信息,以帮助公司形成业务决策.工作内容包括:对数据进行提取,清洗,分析(用描述统计量,趋势分析,多维度分析,假设检验等统计常用方法对数据 ...
- 微信公众号_Deejo说_2019
说明: 1. 文中的内容均来自Deejo说微信公众号 2. 微信中搜索"Deejo说"公众号,可关注 麻麻英语 ——2019.09.10—— It’s my treat. 我来请客 ...
- 使用docker 基于centos7制作mysql镜像
说明:由于业务需要使用centos7.6+mysql5.7+jdk8以及其他的java程序,本想在网上找一个现成的,发现镜像都不适合我. 一.yum方式安装mysql 1.编写dockerfile文件 ...
- js十大排序算法收藏
十大经典算法排序总结对比 转载自五分钟学算法&https://www.cnblogs.com/AlbertP/p/10847627.html 一张图概括: 主流排序算法概览 名词解释: n: ...
- 第06组 Alpha冲刺(1/4)
队名:福大帮 组长博客链接:https://www.cnblogs.com/mhq-mhq/p/11863075.html 作业博客 :https://edu.cnblogs.com/campus/f ...
- 第10组 Beta冲刺(1/5)
链接部分 队名:女生都队 组长博客: 博客链接 作业博客:博客链接 小组内容 恩泽(组长) 过去两天完成了哪些任务 描述 tomcat的学习与实现 服务器后端部署,API接口的beta版实现 后端代码 ...
- curl抓取页面时遇到重定向的解决方法
用php的curl抓取网页遇到了问题,为阐述方便,将代码简化如下: <?php function curlGet($url) { $ch = curl_init(); curl_setopt($ ...
- python3.6安装 zipimport.ZipImportError: can't decompress data; zlib not available【转】
python3.6.3 安装: .tgz cd Python- ./configure make make altinstall `make altinstall` , 报错: zipimport.Z ...
- 【postman】api开发必备神器
1.使用参考:https://blog.csdn.net/fxbin123/article/details/80428216 2.win 下载地址:Postman for windows X64 ...