预统计

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;

}

};

相关推荐
学涯乐码堂主1 小时前
有趣的“打擂台算法”
c++·算法·青少年编程·gesp
Tutankaaa1 小时前
知识竞赛题库设计全攻略
人工智能·算法
WolfGang0073212 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
aini_lovee4 小时前
多目标粒子群优化(MOPSO)双适应度函数MATLAB实现
人工智能·算法·matlab
yong99904 小时前
图像融合与拼接:完整MATLAB工具箱
算法·计算机视觉·matlab
春风不语5054 小时前
深入理解主成分分析(PCA)
算法
apollowing4 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(二十二)
算法·启发式算法·web app
晚枫歌F4 小时前
最小堆定时器
数据结构·算法
Lumos_7774 小时前
Linux -- 线程
java·jvm·算法
七颗糖很甜5 小时前
“十五五”气象发展规划:聚焦五大核心任务
大数据·python·算法