力扣381周赛

2024-01-25 01:12
文章标签 力扣 周赛 381

本文主要是介绍力扣381周赛,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

力扣第381场周赛

文章目录

  • 力扣第381场周赛
    • 输入单词需要的最少按键次数 I
    • 按距离统计房屋对数目 I
    • 输入单词需要的最少按键次数 II
    • 按距离统计房屋对数目 II

输入单词需要的最少按键次数 I

贪心模拟

class Solution {
public:int minimumPushes(string word) {int n = word.size() , ans = 0;for(int i = 0 ; i < n ; i ++){if(i >= 0 && i <= 7)ans += 1;else if(i >= 8 && i < 16)ans += 2;else if(i >= 16 && i < 24)ans += 3;else ans += 4;}return ans;}
};

按距离统计房屋对数目 I

跑一边floyd然后对每两个点统计

class Solution {
public:vector<int> countOfPairs(int n, int x, int y) {vector<vector<int> >d(n + 1 , vector<int>(n + 1));vector<int> ans(n);for(int i = 1 ; i <= n  ; i ++){for(int j = 1 ; j <= n ; j ++){if(i == j)d[i][j] = 0;else d[i][j] = 1e9;}}for(int i = 1 ; i < n ; i ++){d[i][i + 1] = d[i + 1][i] = 1;}if(x != y) d[x][y] = d[y][x] = 1;for (int k = 1; k <= n; k ++ )for (int i = 1; i <= n; i ++ )for (int j = 1; j <= n; j ++ )d[i][j] = min(d[i][j], d[i][k] + d[k][j]);for(int i = 1 ; i <= n ; i ++){for(int j = 1 ; j <= n ; j ++){if(d[i][j] - 1 >= 0)ans[d[i][j] - 1]++;}}return ans;}
};

输入单词需要的最少按键次数 II

在I的基础上价格哈希表即可

class Solution {
public:int minimumPushes(string word) {map<char,int> m;int n = word.size() , ans = 0;vector<int> v(30);for(auto x: word){m[x] ++;}int i = 1;for(auto [x , y] : m){v.push_back(y);}sort(v.begin() , v.end());reverse(v.begin() , v.end());for(auto y : v){if(i >= 1 && i <= 8)ans += y;else if(i >= 9 && i <= 16)ans += (2 * y);else if(i > 16 && i <= 24)ans += (3 * y);else ans += (4 * y);i ++;}return ans;}
};

按距离统计房屋对数目 II

分类讨论

class Solution {
public:vector<long long> countOfPairs(int n, int X, int Y) {if (X > Y) swap(X, Y);vector<long long> ans(n + 1);// 情况三:计算长度为 len 的链内部的贡献auto inner = [&](int len) {for (int i = 1; i <= len; i++) ans[i] += (len - i) * 2;};if (X == Y) {// 没有环的特殊情况inner(n);ans.erase(ans.begin());return ans;}// 情况二:计算元素值为 2,第一个窗口的开头为 L,最后一个窗口的开头为 R 的滑动窗口的贡献auto gao = [&](int L, int R, int len) {// 用差分数组维护滑动窗口经过的值long long delta[n + 2];memset(delta, 0, sizeof(delta));for (int i = L; i <= R; i++) delta[i] += 4, delta[i + len] -= 4;long long now = 0;// 求差分数组前缀和,即可得到对每个距离的贡献for (int i = L; i < R + len; i++) {now += delta[i];ans[i] += now;}};int len = Y - X + 1;vector<int> chains;//链的长度if (n - Y > 0) chains.push_back(n - Y);if (X > 1) chains.push_back(X - 1);if (len & 1) {// 环长为奇数// 情况一:计算环内部的贡献for (int i = 1; i <= len / 2; i++) ans[i] += len * 2;// 情况二:计算一个点在环,一个点在链的贡献for (int c : chains) gao(2, c + 1, len / 2);} else {// 环长为偶数// 情况一:计算环内部的贡献for (int i = 1; i < len / 2; i++) ans[i] += len * 2;ans[len / 2] += len;// 情况二:计算一个点在环,一个点在链的贡献for (int c : chains) {gao(2, c + 1, len / 2 - 1);for (int i = 1; i <= c; i++) ans[i + len / 2] += 2;}}// 情况三:计算链内部的贡献int sm = 2;for (int c : chains) sm += c;inner(sm);// 扣除重复计算的贡献ans[1] -= 2;for (int i = Y + 1; i <= n; i++) ans[i - Y + 1] -= 2;for (int i = X - 1; i > 0; i--) ans[X - i + 1] -= 2;ans.erase(ans.begin());return ans;}
};

这篇关于力扣381周赛的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/641639

相关文章

两数之和--力扣1

两数之和 题目思路C++代码 题目 思路 根据题目要求,元素不能重复且不需要排序,我们这里使用哈希表unordered_map。注意题目说了只对应一种答案。 所以我们在循环中,使用目标值减去当前循环的nums[i],得到差值,如果我们在map中能够找到这个差值,就说明存在两个整数的和为目标值。 如果没有找到,就将当前循环的nums[i]以及下标i放入map中,以便后续查

LeetCode 第414场周赛个人题解

目录 Q1. 将日期转换为二进制表示 原题链接 思路分析 AC代码 Q2. 范围内整数的最大得分 原题链接 思路分析 AC代码 Q3. 到达数组末尾的最大得分 原题链接 思路分析 AC代码 Q4. 吃掉所有兵需要的最多移动次数 原题链接 思路分析 AC代码 Q1. 将日期转换为二进制表示 原题链接 Q1. 将日期转换为二进制表示 思路分析

力扣第347题 前K个高频元素

前言 记录一下刷题历程 力扣第347题 前K个高频元素 前K个高频元素 原题目: 分析 我们首先使用哈希表来统计数字出现的频率,然后我们使用一个桶排序。我们首先定义一个长度为n+1的数组,对于下图这个示例就是长度为7的数组。为什么需要一个长度为n+1的数组呢?假如说总共有三个数字都为1,那么我们需要把这个1放在数组下标为3的位置,假如说数组长度为n,对于这个例子就是长度为3,那么它的

【数据结构与算法 | 灵神题单 | 删除链表篇】力扣3217, 82, 237

总结,删除链表节点问题使用到列表,哈希表,递归比较容易超时,我觉得使用计数排序比较稳,处理起来也不是很难。 1. 力扣3217:从链表中移除在数组中的节点 1.1 题目: 给你一个整数数组 nums 和一个链表的头节点 head。从链表中移除所有存在于 nums 中的节点后,返回修改后的链表的头节点。 示例 1: 输入: nums = [1,2,3], head = [1,2,3,

力扣 739. 每日温度【经典单调栈题目】

1. 题目 理解题意: 1.1. 给一个温度集合, 要返回一个对应长度的结果集合, 这个结果集合里面的元素 i 是 当前 i 位置的元素的下一个更高温度的元素的位置和当前 i 位置的距离之差, 若是当前元素不存在下一个更高温度的元素, 则这个位置用0代替; 2. 思路 本题用单调栈来求解;单调栈就适用于来求当前元素左边或者右边第一个比当前元素大或者小的元素;【单调栈:让栈中的元素保持单调

力扣接雨水

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。 示例 1: 输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]输出:6解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 示例 2: 输入:height

每日一题,力扣leetcode Hot100之238.除自身以外数组的乘积

乍一看这个题很简单,但是不能用除法,并且在O(N)时间复杂度完成或许有点难度。 考虑到不能用除法,如果我们要计算输出结果位置i的值,我们就要获取这个位置左边的乘积和右边的乘积,那么我新设立两个数组L和R。 对于L来说,由于表达的是位置i左边的数的乘积,那么L[0]=1,因为第一个数字左边没数那么为了不影响乘积初始值就设置为1,那么L[1]=L[0]*nums[0],那么L[i]=L[i-1

LeetCode --- 413周赛

题目列表 3274. 检查棋盘方格颜色是否相同 3275. 第 K 近障碍物查询 3276. 选择矩阵中单元格的最大得分 3277. 查询子数组最大异或值 一、检查棋盘方格颜色是否相同 题目给定两个字符串来表示两个方格的坐标,让我们判断这两个方格的颜色是否相同,这里我们要观察棋盘的颜色特征,我们就会发现奇数行的奇数列和偶数行的偶数列是黑色,其他都是白色,所以我们可以直接计算出每个方

力扣 797. 所有可能路径【DFS】

1. 题目 2. 代码 DFS , 直接见代码 class Solution {public:vector<int> path;vector<vector<int>> res; // 结果集void dfs(vector<vector<int>>& graph, int cur, int n){// 找出所有从节点 0 到节点 n-1 的路径// 下标从 0 开始的if (

Java中等题-整数替换(力扣)

给定一个正整数 n ,你可以做如下操作: 如果 n 是偶数,则用 n / 2替换 n 。如果 n 是奇数,则可以用 n + 1或n - 1替换 n 。 返回 n 变为 1 所需的 最小替换次数 。 示例 1: 输入:n = 8输出:3解释:8 -> 4 -> 2 -> 1 示例 2: 输入:n = 7输出:4解释:7 -> 8 -> 4 -> 2 -> 1或 7 ->