1290.二进制链表转整数

1291.顺次数

1292.元素和小于等于阈值的正方形的最大边长

1293.网格中的最短路径

1290.二进制链表转整数

[1290.二进制链表转整数](https://leetcode-cn.com/problems/Convert-Binary-Number-in-a-Linked-List-to Integer)

给你一个单链表的引用结点 head。链表中每个结点的值不是 0 就是 1。已知此链表是一个整数数字的二进制表示形式。

请你返回该链表所表示数字的 十进制值

样例输入与样例输出 Sample Input and Sample Output

示例 1:

![](https://assets.leetcode-cn.com/aliyun-lc-

upload/uploads/2019/12/15/graph-1.png)

**输入:** head = [1,0,1]
**输出:** 5
**解释:** 二进制数 (101) 转化为十进制数 (5)

示例 2:

**输入:** head = [0]
**输出:** 0

示例 3:

**输入:** head = [1]
**输出:** 1

示例 4:

**输入:** head = [1,0,0,1,0,0,1,1,1,0,0,0,0,0,0]
**输出:** 18880

示例 5:

**输入:** head = [0,0]
**输出:** 0

提示 Hint

提示:

  • 链表不为空。
  • 链表的结点总数不超过 30
  • 每个结点的值不是 0 就是 1

代码

/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* ListNode *next;
* ListNode(int x) : val(x), next(NULL) {}
* };
*/
class Solution {
public:
int getDecimalValue(ListNode* head) {
int ans(0);
ListNode *p = head;
while(p != nullptr) {
ans = ans * 2 + (p->val);
p = p->next;
}
return ans;
}
};

1291.顺次数

1291.顺次数

我们定义「顺次数」为:每一位上的数字都比前一位上的数字大 1 的整数。

请你返回由 [low, high] 范围内所有顺次数组成的 有序 列表(从小到大排序)。

样例输入与样例输出 Sample Input and Sample Output

示例 1:

**输出:** low = 100, high = 300
**输出:** [123,234]

示例 2:

**输出:** low = 1000, high = 13000
**输出:** [1234,2345,3456,4567,5678,6789,12345]

提示 Hint

提示:

  • 10 <= low <= high <= 10^9

代码

class Solution {
public:
vector<int> sequentialDigits(int low, int high) {
vector<int>ans = {12,23,34,45,56,67,78,89,123,234,345,456,567,678,789,1234,2345,3456,4567,5678,6789,12345,23456,34567,45678,56789,123456,234567,345678,456789,1234567,2345678,3456789,12345678,23456789,123456789};
vector<int>ret;
int p = lower_bound(ans.begin(),ans.end(),low)-ans.begin();
int n = ans.size();
while(p < n && ans[p] <= high) ret.push_back(ans[p++]);
return ret;
}
};

1292.元素和小于等于阈值的正方形的最大边长

1292.元素和小于等于阈值的正方形的最大边长

给你一个大小为 m x n 的矩阵 mat 和一个整数阈值 threshold

请你返回元素总和小于或等于阈值的正方形区域的最大边长;如果没有这样的正方形区域,则返回 0

样例输入与样例输出 Sample Input and Sample Output

示例 1:

**输入:** mat = [[1,1,3,2,4,3,2],[1,1,3,2,4,3,2],[1,1,3,2,4,3,2]], threshold = 4
**输出:** 2
**解释:** 总和小于 4 的正方形的最大边长为 2,如图所示。

示例 2:

**输入:** mat = [[2,2,2,2,2],[2,2,2,2,2],[2,2,2,2,2],[2,2,2,2,2],[2,2,2,2,2]], threshold = 1
**输出:** 0

示例 3:

**输入:** mat = [[1,1,1,1],[1,0,0,0],[1,0,0,0],[1,0,0,0]], threshold = 6
**输出:** 3

示例 4:

**输入:** mat = [[18,70],[61,1],[25,85],[14,40],[11,96],[97,96],[63,45]], threshold = 40184
**输出:** 2

提示 Hint

提示:

  • 1 <= m, n <= 300
  • m == mat.length
  • n == mat[i].length
  • 0 <= mat[i][j] <= 10000
  • 0 <= threshold <= 10^5

代码

class Solution {
public:
int s[300][300];
int n, m;
int maxSideLength(vector<vector<int>>& mat, int threshold) {
this->n = mat.size(), this->m = mat[0].size();
memset(s, 0, sizeof(s));
for(int i = 0; i < n; ++i)
for(int j = 0; j < m; ++j) {
s[i][j] = mat[i][j];
if(i)
s[i][j] += s[i - 1][j];
if(j)
s[i][j] += s[i][j - 1];
if(i && j)
s[i][j] -= s[i - 1][j - 1];
} int first = 0, middle, half, len = min(n, m);
const int key = threshold;
while(len > 0) {
half = len >> 1;
middle = first + half;
//cout << middle << "\n";
if(cal(middle) > key)
len = half;
else {
first = middle + 1;
len = len - half - 1;
}
}
//cout << "first " << first << "\n";
return cal(first)>key ? first - 1 : first;
} private : int getSum(int x1, int y1, int x2, int y2) {
int ans = s[x2][y2];
if(x1 && y1)
ans += s[x1 - 1][y1 - 1];
if(x1)
ans -= s[x1 - 1][y2];
if(y1)
ans -= s[x2][y1 - 1];
//cout << x1 << " " << y1 << " " << x2 << " " << y2 << ":" << ans << "\n";
return ans;
}
int cal(int x) {
if(x == 0) return 0;
int ans = 0x3f3f3f3f;
for(int i = x - 1; i < n; ++i)
for(int j = x - 1; j < m; ++j) {
int t = getSum(i - x + 1, j - x + 1, i, j);
ans = min(ans, t);
}
//cout << "len " << x << ":" << ans << endl;
return ans;
}
};

1293.网格中的最短路径

[1293.网格中的最短路径](https://leetcode-cn.com/problems/Shortest Path in a Grid with Obstacles Elimination)

给你一个 m * n 的网格,其中每个单元格不是 0(空)就是 1(障碍物)。每一步,您都可以在空白单元格中上、下、左、右移动。

如果您 最多 可以消除 k 个障碍物,请找出从左上角 (0, 0) 到右下角 (m-1, n-1)

的最短路径,并返回通过该路径所需的步数。如果找不到这样的路径,则返回 -1。

样例输入与样例输出 Sample Input and Sample Output

示例 1:

**输入:**
grid =
[[0,0,0],
[1,1,0],
[0,0,0],
[0,1,1],
[0,0,0]],
k = 1
**输出:** 6
**解释:** 不消除任何障碍的最短路径是 10。
消除位置 (3,2) 处的障碍后,最短路径是 6 。该路径是 (0,0) -> (0,1) -> (0,2) -> (1,2) -> (2,2) -> **(3,2)** -> (4,2).

示例 2:

**输入:**
grid =
[[0,1,1],
[1,1,1],
[1,0,0]],
k = 1
**输出:** -1
**解释:** 我们至少需要消除两个障碍才能找到这样的路径。

提示 Hint

提示:

  • grid.length == m
  • grid[0].length == n
  • 1 <= m, n <= 40
  • 1 <= k <= m*n
  • grid[i][j] == 0 **or** 1
  • grid[0][0] == grid[m-1][n-1] == 0

代码

class Solution {
public:
int shortestPath(vector<vector<int>>& grid, int k) {
queue<node>que;
const int inf = 0x3f3f3f3f;
int ans = inf;
n = grid.size(), m = grid[0].size();
que.push(node(0, 0, k, 0)); while(!que.empty()) {
node cur = que.front();
que.pop();
if(grid[cur.r][cur.c])
cur.k--;
vis[cur.r][cur.c][k-cur.k] = true; if(cur.r == n - 1 && cur.c == m - 1 && cur.k >= 0) {
ans = min(ans, cur.s);
}
for(int i = 0, rr, cc; i < 4; ++i) {
rr = cur.r + dr[i], cc = cur.c + dc[i];
if(inBound(rr, cc) && !vis[rr][cc][k-cur.k] && k-cur.k <= n*m) {
que.push(node(rr, cc, cur.k, cur.s + 1));
vis[rr][cc][k-cur.k] = true;
}
}
}
return ans == inf ? -1: ans;
} private :
struct node {
int r, c, k, s; node(int _r,int _c,int _k,int _s):r(_r),c(_c),k(_k),s(_s){};
}; inline bool inBound(int r, int c) {
return r >= 0 && r < n && c >= 0 && c < m;
}
const int dr[4] = {1, -1, 0, 0};
const int dc[4] = {0, 0, 1, -1};
int n,m;
bool vis[41][41][41*41];
};

LeetCode 第 167 场周赛的更多相关文章

  1. LeetCode 第 165 场周赛

    LeetCode 第 165 场周赛 5275. 找出井字棋的获胜者 5276. 不浪费原料的汉堡制作方案 5277. 统计全为 1 的正方形子矩阵 5278. 分割回文串 III C 暴力做的,只能 ...

  2. Leetcode第 217 场周赛(思维量比较大)

    Leetcode第 217 场周赛 比赛链接:点这里 做完前两题我就知道今天的竞赛我已经结束了 这场比赛思维量还是比较大的. 1673. 找出最具竞争力的子序列 题目 给你一个整数数组 nums 和一 ...

  3. Leetcode 第133场周赛解题报告

    今天参加了leetcode的周赛,算法比赛,要求速度比较快.有思路就立马启动,不会纠结是否有更好的方法或代码可读性.只要在算法复杂度数量级内,基本上是怎么实现快速就怎么来了. 比赛时先看的第二题,一看 ...

  4. LeetCode第151场周赛(Java)

    这是我第一次写周赛的题目,而且还是虚拟的.从这次起,以后就将所有错过的题目都写到博客来.当然既然是我错的,那代码肯定不是我自己的.我会注明来源.并且我会自己敲一遍.多总结总是没坏处的. 另外比较糟糕的 ...

  5. LeetCode第152场周赛(Java)

    这算是我第一次正式参加 LeetCode 的周赛吧.通过两道题.意料之中(通过上次模拟可以看出来).总的来说,脑袋还是不太灵光.想的有点慢.全球第一名 0:10:19 就全部通过...感觉我的智商被狠 ...

  6. Leetcode 第137场周赛解题报告

    今天的比赛的题目相对来说比较「直白」,不像前几周都是一些特定的算法,如果你没学过不可能想出来. 做了这些周,对leetcode比赛的题目也发现了一些「规律」. 一般前两道题都很「简单」,只要有想法,直 ...

  7. LeetCode 第 150 场周赛

    一.拼写单词(LeetCode-1160) 1.1 题目描述 1.2 解题思路 由于给定的chars,每个字母只能用一次,所以用大小为26的数组charsArray来表示a-z(例如charsArra ...

  8. LeetCode 第 196 场周赛 (题目:5452-5455,这是参加过最坑的周赛,暴力n^2居然可以过)

    5452. 判断能否形成等差数列   给你一个数字数组 arr . 如果一个数列中,任意相邻两项的差总等于同一个常数,那么这个数列就称为 等差数列 . 如果可以重新排列数组形成等差数列,请返回 tru ...

  9. Leetcode 第136场周赛解题报告

    周日的比赛的时候正在外面办事,没有参加.赛后看了下题目,几道题除了表面要考的内容,还是有些能发散扩展的地方. 做题目不是最终目的,通过做题发现知识盲区,去研究学习,才能不断提高. 理论和实际是有关系的 ...

随机推荐

  1. OpenJudge1.5.6:整数序列的元素最大跨度值

    描述 给定一个长度为n的非负整数序列,请计算序列的最大跨度值(最大跨度值 = 最大值减去最小值). 输入一共2行,第一行为序列的个数n(1 <= n <= 1000),第二行为序列的n个不 ...

  2. TCP SACK 介绍 转载

    一.SACK选项 默认情况下TCP采取的是累积确认机制,这时如果发生了报文乱序到达,接收方只会重复确认最后一个按序到达的报文段,为此发送方的处理只能是重复按序到达接收方的报文段之后的那个报文段,因而它 ...

  3. linux安装puppeteer

    1.安装 下载淘宝镜像的,可以同时下载puppeteer和chromium下面两条语句即可 npm install -g cnpm --registry=https://registry.npm.ta ...

  4. 2019balsn两道web和2019巅峰极客一道web记录

    遇到3道有点意思的web,记录一下~ web1 题目地址:http://warmup.balsnctf.com/ 源码如下所示: <?php if (($secret = base64_deco ...

  5. servlet多线程安全问题

    Servelet多线程安全问题 原因 一个servlet被实例化一次,当有多个用户访问时,多个线程会访问同一个实例,实例变量就会被不同的用户修改. 简单的案例 新建servlet,访问http://l ...

  6. HTTP之基本认证机制

    1. 认证 1.1 HTTP 的质询/响应认证框架 HTTP 提供了一个原生的质询/响应(challenge/response)框架,简化了对用户的认证过程. HTTP 的认证模型如下图所示: Web ...

  7. Truffle测试框架

    Truffle测试框架 2018年06月08日 19:01:19 tianlongtc 阅读数 1000   Truffle 有一个标准的自动化测试框架,让你可以非常方便地测试您的合约.这个框架允许您 ...

  8. 检测系统中进程占满单个cpu的情况

    #!/bin/bash function thread_used_cpu(){ # $1 为单个cpu负载的百分比 if [[ $1 == "" ]];then full_load ...

  9. Vue —— 从环境搭建到发布

    之前学习 Vue 的时候也是按着别人的文档一步步下载安装构建项目再运行,为了避免忘记步骤,所以还是记在这吧. 参考链接: https://www.zybuluo.com/xudongh/note/75 ...

  10. CameraLink标准学习

     CameraLink标准学习