-
cpp
class Solution { public: int monotoneIncreasingDigits(int n) { string s = to_string(n); int flag = s.size(); for(int i = s.size() - 1; i > 0; i -- ) { if(s[i] < s[i - 1]) { flag = i; s[i - 1] --; } } for(int i = flag; i < s.size(); i++ ) { s[i] = '9'; } return stoi(s); } };前一个数字 > 当前数字,说明单调性被破坏,需要把前一个数字 减 1,并把它后面的所有数字变为 '9'
-
cpp
class Solution { public: vector<int> partitionLabels(string s) { int hash[26] = {0}; vector<int>result; int left = 0; int right = 0; for(int i = 0 ; i < s.size(); i ++ ) { hash[s[i] - 'a'] = i; } for(int i = 0; i < s.size() ; i++ ) { right = max(right, hash[s[i] - 'a']); if(i == right) { result.push_back(right - left + 1); left = i + 1; } } return result; } };用个hash表保存
-
cpp
class Solution { public: static bool cmp(vector<int>& a, vector<int>& b) { return a[0] < b[0]; } vector<vector<int>> merge(vector<vector<int>>& intervals) { sort(intervals.begin(),intervals.end(),cmp); vector<vector<int>>result; result.push_back(intervals[0]); for(int i = 1 ; i < intervals.size(); i ++ ) { if(result.back()[1] >= intervals[i][0]) { result.back()[1] = max(result.back()[1],intervals[i][1]); }else { result.push_back(intervals[i]); } } return result; } };先把第一个存入,再依次比较。
-
线程安全的单例
cppclass singleton { public: static singleton &getinstance() { static singleton instance; return instance; } singleton (const singleton &) = delete; singleton& operator= (const singleton&) = delete; private: singleton() { } ~singleton() { } }; int main() { singleton& pinstance = singleton::getinstance(); }
贪心+线程安全单例
TheLegendMe2025-11-28 12:28
相关推荐
全糖可乐气泡水1 小时前
Codex适配国产信创环境安装部署与技术适配全解析h_a_o777oah1 小时前
状态机+划分型 DP :深度解析K-划分问题下 DP 状态的转移逻辑(洛谷P2679 P2331 附C++代码)05候补工程师1 小时前
从算法理想向工程现实的跨越:SLAM 核心架构、思维误区与 Nav2 实战避坑指南手写码匠2 小时前
Android 17 适配实战指南:新特性解读、隐私变更与迁移全攻略珊瑚里的鱼3 小时前
leetcode42雨水水木流年追梦3 小时前
大模型入门-大模型的推理策略生成论实验室3 小时前
用事件关系网络重新理解AI(三):激活函数、微调与元学习Narv工程师3 小时前
嵌入式机器人控制器算力评估:从DMIPS到WCET的完整指南蒟蒻的贤3 小时前
实训1227liulilittle3 小时前
TCP UCP:基于卡尔曼滤波的BBR增强型拥塞控制算法