预统计

lc826

++// 记得预处理:维护每个难度对应的最大收益
for(int i=1;i<n;i++){
dp[i].second = max(dp[i].second, dp[i-1].second);
++

class Solution {

public:

int maxProfitAssignment(vector<int>& difficulty, vector<int>& profit, vector<int>& worker)

{

vector<pair<int,int>> dp;

int m=worker.size(),n=difficulty.size();

for(int i=0;i<n;i++)

{

dp.push_back({difficulty[i],profit[i]});

}

sort(dp.begin(),dp.end());

++// 预处理:维护每个难度对应的最大收益
for(int i=1;i<n;i++){
dp[i].second = max(dp[i].second, dp[i-1].second);
++

}

int ret=0;

for(int i=0;i<m;i++)

{

int t=upper_bound(dp.begin(),dp.end(),make_pair(worker[i], INT_MAX))-dp.begin()-1;

if(t>=0) ret+=dp[t].second;

}

return ret;

}

};

lcr49

++if(!node->left && !node->right)
{
int t=stoi(path);
ret+=t;
}
else
++

class Solution {

public:

int sumNumbers(TreeNode* root)

{

string path;

int ret=0;

auto dfs=[&](this auto&& dfs,TreeNode* node)

{

if(!node)

return;

path+=(node->val+'0');

++if(!node->left && !node->right)
{
int t=stoi(path);
ret+=t;
}
else
++

{

dfs(node->left);

dfs(node->right);

}

path.pop_back();

};

dfs(root);

return ret;

}

};

lc1457

mask优化回溯

init 0

  • ^(1<<i) 实现标记

__builtin_popcount(mask) <= 1 实现统计

class Solution {

public:

int pseudoPalindromicPaths (TreeNode* root)

{

int mask = 0, ret = 0; // mask用二进制位记录数字出现次数的奇偶

auto dfs=[&](this auto&& dfs,TreeNode* node) {

if(!node) return;

mask ^= (1 << node->val); // 异或:出现次数奇偶翻转

if(!node->left && !node->right) {

// 伪回文:mask中1的数量≤1

ret += (__builtin_popcount(mask) <= 1);

} else {

dfs(node->left);

dfs(node->right);

}

mask ^= (1 << node->val); // 回溯

};

dfs(root);

return ret;

}

};

string 和 unordered_map 效率低了tle了..

++// 仅叶子节点检查路径++

++if(!node->left && !node->right)++

++if(check(path)) ret++;++

class Solution {

public:

int pseudoPalindromicPaths (TreeNode* root)

{

string path;

int ret=0;

auto check=[&](string s) {

unordered_map<char,int> hash;

for(auto& c:s) hash[c]++;

bool f=false;

for(auto& [_,b]:hash)

{

if(b%2==1)

{

if(!f) f=true;

else return false;

}

}

return true;

};

auto dfs=[&](this auto&& dfs,TreeNode* node) {

if(!node) return;

path.push_back(node->val+'0');

++// 仅叶子节点检查路径++

++if(!node->left && !node->right) {++

++if(check(path)) ret++;++

}

else {

dfs(node->left);

dfs(node->right);

}

path.pop_back();//回溯

};

dfs(root);

return ret;

}

};

lc1267

预处理统计行列

class Solution {

public:

int countServers(vector<vector<int>>& grid)

{

int m = grid.size(), n = grid[0].size();

vector<int> row(m, 0), col(n, 0);

// 先统计每行、每列的服务器数量

for (int i = 0; i < m; i++) {

for (int j = 0; j < n; j++) {

if (grid[i][j] == 1) {

row[i]++;

col[j]++;

}

}

}

int ret = 0;

// 遍历每个服务器,判断其行/列是否有至少2个服务器

for (int i = 0; i < m; i++) {

for (int j = 0; j < n; j++) {

if (grid[i][j] == 1 && (row[i] > 1 || col[j] > 1)) {

ret++;

}

}

}

return ret;

}

};

相关推荐
csdn_aspnet20 分钟前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
m0_629494733 小时前
LeetCode 热题 100-----26.环形链表 II
数据结构·算法·leetcode·链表
壹号用户3 小时前
用队列实现栈
数据结构·算法
做人求其滴3 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
daad7774 小时前
记一组无人机IMU传感器数据
算法
计算机安禾4 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
小O的算法实验室4 小时前
2026年KBS,流形感知强化学习差分进化算法+不规则3D无人机路径规划,深度解析+性能实测
算法·智能算法·智能算法改进
玖釉-4 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
不做无法实现的梦~4 小时前
运动控制系统复习一览-----常考题目总结版本
算法