出入度|bfs|状压dp

lc1349

状压dp

二进制数表示每行座位的学生就座状态

校验每行及相邻行的就座合法性后

递推计算能坐下的最大学生数

class Solution {

public:

int maxStudents(vector<vector<char>>& seats) {

int m = seats.size();

int n = seats0.size();

vector<vector<int>> dp(m + 1, vector<int>(1 << n));

for (int row = 1; row <= m; ++row)

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

bitset<8> bs(i);

bool ok = true;

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

if (bsj && seatsrow-1j == '#' || (j < n - 1 && bsj && bsj + 1)) {

ok = false;

break;

}

}

if (!ok) {

dprowi = -1;

continue;

}

for (int last = 0; last < (1 << n); ++last) {

if (dprow - 1last == -1)

continue;

bitset<8> lbs(last);

bool ok = true;

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

if (lbsj && ((j > 0 && bsj - 1) || (j < n - 1 && bsj + 1))) {

ok = false;

break;

}

}

if (ok)

dprowi = max(dprowi, dprow - 1last + (int)bs.count());

}

}

int ans = 0;

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

ans = max(ans, dpmi);

return ans;

}

};

lcp9

✓小球从编号0的弹簧出发,在第i个弹簧处按动时,可向右弹 jumpi 距离(弹出去就完成)

或向左弹到任意左侧弹簧(0处不能左弹),求把小球弹出机器的++最少按动弹簧次数++

BFS结合前驱位置优化遍历

向右跳弹簧位置、向左遍历未访问的前驱位置

找到跳出弹簧数组的最少按动次数

class Solution {

public:

int minJump(vector<int>& jump)

{

int n = jump.size();

queue<pair<int, int>> q;

q.emplace(0, 0);

vector<bool> seen(n, false);

++seen0 = true;++

++//实现每个地方只过一遍的记忆化++

int preidx = 1;

while (!q.empty()) {

auto idx, d = q.front();

q.pop();

int next = idx + jumpidx;

if (next > n - 1)

return d + 1;

++if (!seennext) {++

seennext = true;

++q.emplace(next, d + 1);++

}

++while (preidx < idx) {++

if (!seenpreidx) {

seenpreidx = true;

q.emplace(preidx, d + 1);

}

++preidx++;++

}

}

return -1;

}

};

lcp62

/*

交通枢纽: 入度为n-1, 出度为0

*/

class Solution {

public:

int transportationHub(vector<vector<int>>& path) {

int d10102 = {0};

++// di0: i的入度, di1: i的出度
unordered_set<int> s; // 存哪些城市
++

for (auto& p : path) {

dp\[0]1++, dp\[1]0++;

s.insert(p0);

s.insert(p1);

}

int n = s.size(); // 共n个城市

for (auto city : s)

{ // 交通枢纽: 入度为n-1, 出度为0的城市

if (dcity0 == n - 1 && dcity1 == 0) return city;

}

return -1;

}

};

相关推荐
小欣加油5 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly6 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕7 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei7 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld8 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi89 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang10 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby11 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠11 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力12 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试