31.哀家要长脑子了!

2024-06-12 04:28
文章标签 31 要长 脑子 哀家

本文主要是介绍31.哀家要长脑子了!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

不行啊 这个不能停啊

1.451. 根据字符出现频率排序 - 力扣(LeetCode)

哎哟,每次朦朦胧胧似懂非懂的,一看到感觉就是用无序map,但是让我上手我又不知道怎么写了,烦死了!

说一下:用一个unordered_map统计每个字符出现的次数,因为它是unordered的,所以它是不支持按key或者按value排序的,把它再放进一个数组可以用sort函数按字符的出现次数排序呀,最后遍历这个数组,看字符出现次数出现了几次,构造字符串的时候,相应字符也要出现几次。

class Solution {
public:string frequencySort(string s) {unordered_map<char, int>map;for(char ch : s){map[ch]++;}vector<pair<char,int>> vec;for(auto &it : map){vec.emplace_back(it);}sort(vec.begin(), vec.end(), [](const pair<char, int> &a, const pair<char, int> &b)                        {    return a.second > b.second; });string res;for(auto &[ch, num] : vec){for(int i = 0; i < num; i++){res += ch;}} return res;}
};

for(auto &[ch, num] : vec)

这这这是一个foreach语句,在这里,[ch, num]就是结构化绑定的部分,它告诉编译器从迭代的元素中解构出两个部分,并分别绑定到str和num这两个变量上

 sort(vec.begin(), vec.end(), [](const pair<char, int> &a, const pair<char, int> &b){       
        return a.second > b.second; 
       });

这这这是一个lambda表达式,我说第三个。

Lambda表达式语法定义

[capture list] (parameters) mutable throw() -> return type { statement }

  捕获列表       参数列表   可变规格异常说明    返回类型       函数体        

  1. 捕获列表:在C++规范中也称为Lambda导入器,捕获列表总是初夏在Lambda函数的开始处。实际上,[ ]是Lambda引出符。编译器根据该引出符判断接下来的代码是否是Lambda函数,捕获列表能够捕捉上下文中的变量以供Lambda函数使用。换句话说,Lambda表达式常常会被用在一个函数里,但它只能访问外部的全局变量而并不能访问函数里的局部变量列表,只要被列在了列表内,那么表达式都可以对其进行访问。
    捕获变量的方式有三种:    
            • 按值捕获(capture by value)   
            • 按引用捕获(capture by reference)   
            • 按值捕获(implict capture)                
2.696. 计数二进制子串 - 力扣(LeetCode) 

巧妙太巧妙了

把每一部分连续的0或连续的1的长度记录下来,长度比较 小的那一个就是对于这部分的0、1来说可以满足题目条件的子串的出现次数

class Solution {
public:int countBinarySubstrings(string s) {vector<int> counts(26);int i = 0, len = s.size();while(i < len){char ch = s[i];int count = 0;while(i < len && ch == s[i]){i++, count++;}counts.push_back(count);}int res = 0;for(int i = 1; i < counts.size(); i++){res += min(counts[i], counts[i-1]);} return res;}
};

我真的觉得6

3.467. 环绕字符串中唯一的子字符串 - 力扣(LeetCode) 

求不同非空子串在base中出现的个数,其实就是求最长的连续子串捏,就是说,每个以某字母结尾的最长连续子串能贡献的唯一子串数量恰好就是它的长度,因为连续子串中的每一个前缀都是一个有效子串(参考示例3)

所以在这里,维护一个数组dp,其中dp[i]表示以字母表中第i个字母结尾的最长连续子串的长度

class Solution {
public:int findSubstringInWraproundString(string s) {// 用一个dp数组 里面放着以当前字母为结尾的最长连续子串vector<int> dp(26);int k  = 0;for(int i = 0; i < s.size(); i++){// 看看这两个字母之间是不是连续的 // +26的原因是a-z会是-1 这样+26取模也会是1// %可以类比循环队列操作if(i && (s[i] - s[i-1] + 26) % 26 == 1){k++;}else{k = 1;}// 当当前记录的连续子串的长度大于之前记录的长度 此时才会更新 重新记录dp[s[i] - 'a'] = max(dp[s[i] - 'a'], k);}return accumulate(dp.begin(), dp.end(), 0);}
};

其实我有点懵懵懂懂的,我只能写个注释了。。。

这篇关于31.哀家要长脑子了!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux 删除 当前下的 mysql-8.0.31 空文件夹

在Linux中,如果你想要删除当前目录下的名为mysql-8.0.31的空文件夹(即该文件夹内没有任何文件或子文件夹),你可以使用rmdir命令。但是,如果mysql-8.0.31文件夹并非完全为空(即它包含文件或子文件夹),rmdir命令会失败。 如果你的目标是删除mysql-8.0.31文件夹及其内部的所有内容(无论是否为空),你应该使用rm命令结合-r(或-R,它们是等价的)选项来递归地删

尝试用java spring boot+VUE3实现前后端分离部署(8/31)

前言         这几天开学了,公司这边几个和学校对接的项目都挺忙的,然后我又开始有点闲的情况了。问大佬能不能继续看看若依的项目,大佬让我自己去学了。在看若依的项目的时候在想,python的FLASK后端实现和JAVA spring boot的实现差别大不大,两者实现的思路估计大差不差,那具体的代码逻辑和代码实现又有多大差别,java面向对象的编程思想又是怎么体现的。这些想法迫使我将原来使用

[C/C++入门][进制原理]31、求分数序列和

题目来自于信息学奥赛 1078 分析: 这道题看起来比较复杂,实际上只需要通过两个公式,一次性求出分母和分子,然后把这个求出来的数加入到变量和中。甚至都不需要知道总共游哪些数。数组都用不上。循环就能解决。 #include <iostream>#include <iomanip> // 用于格式化输出using namespace std;int main() {double s

“弹性盒子”一维布局系统(补充)——WEB开发系列31

弹性盒子是一种一维布局方法,用于根据行或列排列元素。元素可以扩展以填补多余的空间,或者缩小以适应较小的空间,为容器中的子元素提供灵活的且一致的布局方式。 一、什么是弹性盒子? CSS 弹性盒子(Flexible Box Layout,简称 Flexbox)是 CSS3 中引入的一种布局模式,提供一种有效的方式来布局、对齐和分配容器内空间,特别是在动态和复杂的应用界面中。 1、

redis 实现单位时间内错误记录 时间到key值就被清除------最近脑子不好使觉得还是写个博客试试

直接在客户端操作的, 所以需要redis的简单命令  去对比JAVA客户端jedis的命令就行   添加---set     格式 set  key  value  EX time(秒)   如果这个time不添加的话 ,那默认就是 永久 获取--get    格式 get key  ---查看剩余时间    格式 TTL key ---实现key实现自增: inrc key

Linux入门攻坚——31、rpc概念及nfs和samba

NFS:Network File System     传统意义上,文件系统在内核中实现 RPC:函数调用(远程主机上的函数),Remote Procedure Call protocol     一部分功能由本地程序完成     另一部分功能由远程主机上的 NFS本质上是一种RPC的实现。 本地用户进程要使用文件系统,通过系统调用,由内核完成文件系统的操作,而NFS只不过是系统内核又通过RP

LeetCode 31 Next Permutation

题意: 给出一串数字,求该排列的下一个排列。如果该排列为字典序最大排列,则输出字典序最小排列。 思路: 首先C++里面有求下一个排列的函数next_permutation,该函数返回0即表示当前排列字典序最大。 如果要自己动手实现,那么就考虑“如何找到比当前排列大1的排列”。 假设排列A(aaaXddd)比排列B(aaaYfff)大1,a部分为两排列相同部分,X与Y表示最靠左边不同

C++相关概念和易错语法(31)(特殊类的设计、new和delete底层调用分析)

特殊类的设计 在实践过程中,我们难免会接触到一些需要实现特定功能的类。像之前提过的unique_ptr就是直接delete拷贝构造和赋值函数。下面会分享一些常见的特殊类的实现 1、防拷贝和防赋值 通过封死拷贝构造和赋值函数来保护对象里面内容不被复制。如果对象里面的内容是指针,对析构次数有严格要求的话(如unique_ptr)就通常采用这种处理方法。 注意拷贝构造和移动拷贝为一体,赋值重

Python精选200Tips:31-40

With dreams ahead, I fear no storms 031 any032 all033 try034 del035 not036 return037 with038 yield039 next040 from 运行系统:macOS Sonoma 14.6.1 Python编译器:PyCharm 2024.1.4 (Community Edition) Pytho

有理有据!为什么String选择数字31作为hashCode方法乘子?

点击上方“朱小厮的博客”,选择“设为星标” 回复”1024“获取独家整理的学习资料 来源:http://1t.click/Xkk 1. 背景 某天,我在写代码的时候,无意中点开了 String hashCode 方法。然后大致看了一下 hashCode 的实现,发现并不是很复杂。但是我从源码中发现了一个奇怪的数字,也就是本文的主角31。这个数字居然不是用常量声明的,所以没法从字面意思上推断