-
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
相关推荐
MM_MS4 小时前
Halcon变量控制类型、数据类型转换、字符串格式化、元组操作独自破碎E5 小时前
【二分法】寻找峰值mit6.8245 小时前
位运算|拆分贪心ghie90906 小时前
基于MATLAB的TLBO算法优化实现与改进恋爱绝缘体16 小时前
2020重学C++重构你的C++知识体系wuk9986 小时前
VSC优化算法MATLAB实现Z1Jxxx6 小时前
加密算法加密算法乌萨奇也要立志学C++6 小时前
【洛谷】递归初阶 三道经典递归算法题(汉诺塔 / 占卜 DIY/FBI 树)详解vyuvyucd7 小时前
C++引用:高效编程的别名利器鱼跃鹰飞7 小时前
Leetcode1891:割绳子