Leetcode第309场周赛

Date: September 4, 2022
Difficulty: medium
Rate by others: ⭐⭐⭐⭐
Time consuming: 1h30min
在这里插入图片描述

题目链接

竞赛 - 力扣 (LeetCode)

题目解析

2399. 检查相同字母间的距离

class Solution {public:bool checkDistances(string s, vector<int>& distance) {vector<int> arr(26, -1);int n = s.size(), t;for (int i = 0; i < n; ++i) {t = s[i] - 'a';if (arr[t] == -1) arr[t] = i;else if (i - arr[t] - 1 != distance[t]) return false;}return true;}};

没什么可说的,简单模拟题。

2400. 恰好移动 k 步到达某一位置的方法数目

class Solution {static constexpr int MAXN = 1050;static constexpr int MOD = 1e9 + 7;vector<vector<int>> memo_;public:Solution(): memo_(MAXN, vector<int>(MAXN, -1)) {}int aux(int dis, int k) {dis = std::abs(dis);if (memo_[dis][k] != -1) return memo_[dis][k];if (dis > k) memo_[dis][k] = 0;else if (dis == k) memo_[dis][k] = 1;else memo_[dis][k] = aux(dis - 1, k - 1) + aux(dis + 1, k - 1);if (memo_[dis][k] > MOD) {memo_[dis][k] %= MOD;}return memo_[dis][k];}int numberOfWays(int startPos, int endPos, int k) {return aux(endPos - startPos, k);}};

力扣

看了一眼题解,发现真的是道数学题,自己没有推出来,没有想到去思考用排列组合的想法去做。其实就算想到组合数,自己可能也想不到用递推式的做法O(k2)O(k^2)O(k2)或者O(k)O(k)O(k)去求组合数,而且还需要求逆元,相比之下自己用记忆化搜索硬搞出来也挺不容易的。用记忆化搜索的一个关键在于首先是用距离表示减少变量,然后是负距离和正距离是等价的。

什么时候应该总结一下组合数、逆元这部分的知识。

2401. 最长优雅子数组

class Solution {public:int longestNiceSubarray(vector<int>& nums) {constexpr int MAXN = 1e5 + 5;constexpr int N = 31;vector<int> BITS(N);int t = 1;for (int i = 0; i < N; ++i) {BITS[i]= t;t <<= 1;}vector<int> memo(N, -1);int n = nums.size();int ans = 0, last = -1;for (int i = 0; i < n; ++i) {t = -1;for (int j = 0; j < N; ++j) {if (nums[i] & BITS[j]) {t = std::max(t, memo[j]);memo[j] = i;}}last = std::max(t, last);ans = std::max(ans, i - last);}return ans;}};

自己的思路总体上没有什么问题,就是滑动窗口,每次将左边窗口移动到元素最近的&不为0的位置的后面,这个区间内右边元素和区间内的元素&都是0,但是不能保证在这个区间内前面的元素&为0,需要保存元素的最右左区间,也就是说在这个区间任意两个元素&都为0,也就是优雅子区间。

看了一下其他人的写法,发现自己可以复用左区间的位置,当时还是对题目的理解不够深刻。

2402. 会议室 III

class Solution {public:int mostBooked(int n, vector<vector<int>>& meetings) {using ll = long long;vector<vector<ll>> room(n);sort(meetings.begin(), meetings.end(), [&](auto &&a, auto &&b) {return a[0] < b[0];});for (auto &&meeting : meetings) {bool flag = false;for (int i = 0; i < n; ++i) {if (room[i].empty() || meeting[0] >= room[i].back()) {room[i].push_back(meeting[1]);flag = true;break;}}if (flag) continue;ll minT = room[0].back();int minI = 0;for (int i = 0; i < n; ++i) {if (room[i].back() < minT) {minT = room[i].back();minI = i;}}room[minI].push_back(meeting[1] - meeting[0] + room[minI].back());}int ansN = 0, ansIdx;for (int i = 0; i < n; ++i) {if (room[i].size() > ansN) {ansN = room[i].size();ansIdx = i;}}return ansIdx;}};

写完前三道题时间只剩下十几分钟了,本来想放弃这道题,但是看了一眼题目觉得就是一个很简单的模拟题嘛,踌躇了一会还是开始写,越写越觉得简单,结果11:55提交一次爆long long,改正没有改正完全,12:02通过了,还是有些遗憾。不过没有注意题目的数据范围,这个锅我自己背。

周赛总结

优点

总体思维比较活跃,思维转换速度比较快,实现也还可以。虽然和厉害的人相比还是有差距,但是我觉得已经很不错了,尤其是第二题在没有思路的情况下用记忆化搜索过了真不错。

缺点

还是有些不自信,第四题如果我在第三题做完就全力以赴可能是可以A的,另一个方面是自己忘记去看数据范围了,导致爆long long,改正又忘记后面没有改,自食恶果。

改进方案

多加训练,再接再厉。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/383505.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++ 模板函数、模板类:如果没有被使用就不会被实例化

C中如果一个模板函数没有使用过&#xff0c;那么其局部静态变量都不会被实例化&#xff1a; class A { public:A() {edward::print("A ctor");} };template<typename T> void test() {static A a; }int main() {test<int>(); //如果注释掉则不会有输出r…

C++ 条件变量的使用

绪论 并发编程纷繁复杂&#xff0c;其中用于线程同步的主要工具——条件变量&#xff0c;虽然精悍&#xff0c;但是要想正确灵活的运用却并不容易。 对于条件变量的理解有三个难点&#xff1a; 为什么wait函数需要将解锁和阻塞、唤醒和上锁这两对操作编程原子的&#xff1f;为…

C++Primer学习笔记:第1章 开始

本博客为阅读《C Primer》&#xff08;第5版&#xff09;的读书笔记 ps:刚开始的时候我将所有的笔记都放在一篇博客中&#xff0c;等看到第六章的时候发现实在是太多了&#xff0c;导致我自己都不想看&#xff0c;为了日后回顾&#xff08;不那么有心理压力&#xff09;&#…

【ubuntu】ubuntu14.04上安装搜狗输入法

** 在ubuntu14.04.4 desktop 64amd版本上安装sogou输入法 ** 0.换安装源为中国源&#xff08;可选&#xff0c;下载会快些&#xff09; 1.搭fcitx环境 2.安装sogou for linux 详细步骤&#xff1a; 因为sogou中文输入法基于fcitx(Free Chinese Input Toy for X),需要先搭环境…

【ubuntu】ubuntu下用make编译程序报错找不到openssl/conf.h

ubuntu下用make编译程序报错找不到openssl/conf.h 安装libssl-dev:i386&#xff0c;sudo apt-get install libssl-dev:i386 看好版本&#xff0c;如果不加i386默认下载的是32位&#xff0c;用ln命令连接过去也还是用不了的!libssl.dev安装好后&#xff0c;用find / -name libs…

【ubuntu】ubuntu如何改变系统用户名

ubuntu如何改变系统用户名 方法1&#xff1a;修改现有用户名 方法2&#xff1a;创建新用户&#xff0c;删掉旧用户 方法1&#xff1a; * *—&#xff01;&#xff01;&#xff01;有博客说要先改密码&#xff0c;再改用户名&#xff0c;否则会出现无法登陆状况&#xff01;&…

什么是signal(SIGCHLD, SIG_IGN)函数

什么是signal(SIGCHLD, SIG_IGN)函数 在进行网络编程时候遇到这个函数的使用&#xff0c;自己学习结果如下&#xff0c;有不对请帮忙指正:) signal(SIGCHLD, SIG_IGN)打开manpage康一康~ sighandler_t signal ( int signum, sighandler_t handler );参数1 int signum: 就是…

ssh连接不上linux虚拟机

ssh连接不上linux虚拟机 1.开启ssh服务 linux虚拟机下命令行输入&#xff1a; start service ssh如果显示没有ssh&#xff0c;就下面两个试一试哪一个ok&#xff0c;安装一下ssh&#xff1a; sudo apt-get install openssh-server sudo apt-get install sshd2.还有人说可能是…

没写client,想先测试server端怎么办?

没写client&#xff0c;想先测试server端怎么办&#xff1f; 办法&#xff1a; 1.先打开终端./server&#xff0c;运行起来server 2.再开一个终端&#xff0c; 输入nc 127.0.0.1 8888 回车&#xff08;这里port号要和server里边设置的一致&#xff0c;127.0.0.1是和本机的测试…

【报错解决】linux网络编程报错storage size of ‘serv_addr’ isn’t known解决办法

linux网络编程报错storage size of ‘serv_addr’ isn’t known解决办法 报错如下&#xff1a; server.c:18:21: error: storage size of ‘serv_addr’ isn’t known struct sockaddr_in serv_addr, clit_addr; ^server.c:18:32: error: storage size of ‘clit_addr’ isn’…

【c】写头文件要加#ifndef,#define, #endif

头文件首位 编写.h时&#xff0c; 最好加上如下&#xff0c;用来防止重复包含头文件&#xff1a; 例如&#xff1a; 要编写头文件test.h 在头文件开头写上两行&#xff1a;#ifndef _TEST_H#define _TEST_H// 文件名的大写#endif头文件结尾写上一行&#xff1a;#endif这样做是为…

【c】【报错解决】incompatible implicit declaration

【报错解决】incompatible implicit declaration 背景; 1.自己封装的函数wrap.c包含&#xff1a; #include "wrap.h"2.主函数调用如下&#xff1a; #include <stdio.h> #include <stdlib.h> ... #include <errno.h> #include "wrap.h"…

【ubuntu】vim语法高亮设置无效

如果你的.vimrc配置了语法高亮&#xff0c;但是你的vim没实现&#xff0c;可能你的vim是vim-tiny的黑白版本&#xff0c;你需要vim-gnome这个带GUI的彩色版本。 apt-get update apt-get upgrade apt-get install vim-gnome reboot打开vi就能看到彩色啦

__attribute__机制介绍

1. __attribute__ GNU C的一大特色&#xff08;却不被初学者所知&#xff09;就是__attribute__机制。 __attribute__可以设置函数属性(Function Attribute)、变量属性(Variable Attribute)和类型属性(Type Attribute) __attribute__前后都有两个下划线&#xff0c;并且后面会紧…

【git】git基本操作命令

1.建立本地仓库 git config --global user.name "lora" git config --global user.email "xxxgmail.com"2.建立目录 mkdir xxx3.初始化 cd xxx //进入目录 git init //初始化4.将代码上传至本地缓存区 git add . //上传全部 git add 文件名 //…

【git】解决gitlab ip更改问题

有时候因为部署gitlab虚拟机的ip发生变化&#xff0c;gitlab的clone地址没有同时更新到新的ip&#xff0c; 这导致后续clone报错&#xff0c;解决办法如下&#xff1a; 进入部署gitlab的主机&#xff1a; sudo vim /opt/gitlab/embedded/service/gitlab-rails/config/gitlab.…

gcc -l参数和-L参数

-l参数就是用来指定程序要链接的库&#xff0c;-l参数紧接着就是库名&#xff0c;那么库名跟真正的库文件名有什么关系呢&#xff1f;就拿数学库来说&#xff0c;他的库名是m&#xff0c;他的库文件名是libm.so&#xff0c;很容易看出&#xff0c;把库文件名的头lib和尾.so去掉…

【jenkins】jenkins CI/CD搭建基本过程

1.安装 &#xff08;1&#xff09;安装java &#xff08;2&#xff09;安装jenkins &#xff08;3&#xff09;修改jenkins用户名密码配置 &#xff08;4&#xff09;启动jenkins 2. 插件安装换源 &#xff08;1&#xff09;插件高级选项换地址 &#xff08;2&#xff09;修改…

apt-get常用命令

一&#xff0c;什么的是apt-get 高级包装工具&#xff08;英语&#xff1a;Advanced Packaging Tools,简称&#xff1a;APT&#xff09;是Debian及其衍生发行版&#xff08;如&#xff1a;ubuntu&#xff09;的软件包管理器。APT可以自动下载&#xff0c;配置&#xff0c;安装二…

【jenkins】jenkins build项目的三种方式

jenkins致力于CI/CD&#xff0c; 更改代码只需要在gitlab push之后&#xff0c;jenkins重新build便可以在tomcat上实现更新部署。 以下为三种构建方式&#xff1a; 1.freestyle project 0. 安装插件Deploy to container, 并安装凭证 github连接创建item设置build和post-build …