dfs|mask^翻转

lcr86

++DFS+回溯++

++从字符串起始位置逐步截取子串++,判断子串是否是回文,若是则加入当前分割路径,直到遍历完整个字符串,最终收集所有回文分割的组合。

class Solution

{

string s;

vector<vector<string>> ret;

vector<string> path;

int n;

public:

vector<vector<string>> partition(string s) {

this->s=s;

n=s.size();

dfs(0);

return ret;

}

void dfs(int p)

{

if(p==n)

{

ret.push_back(path);

return;

}

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

{

string t=s.substr(p,i-p);

//从p位置开始 截取长度

string r=t;

reverse(r.begin(),r.end());

if(r==t)

{

path.push_back(t);

dfs(i);

path.pop_back();//回溯下一种可能

}

}

}

};

lc627

注意到:灯泡状态周期是6 开关周期是4

int init_mask = (1 << n) - 1;

//1111.. open

int m1 = mask ^ ((1 << n) - 1);

//和全1异或 实现取反

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

m4 ^= (1 << i);//隔3翻转

class Solution {

public:

int flipLights(int n, int presses)

{

n = min(n, 6);

++int init_mask = (1 << n) - 1;++

++//1111.. open++

unordered_set<int> states;

bool memo[101][1<<6] = {false};

auto dfs = [&](this "auto&&")

{

if (ops == 0) {

states.insert(mask);

return;

}

if (memo[ops][mask]) return;

memo[ops][mask] = true;

++int m1 = mask ^ ((1 << n) - 1);++

++//和全1异或 实现取反++

dfs(ops-1, m1);

int m2 = mask;

for (int i = 1; i < n; i += 2) m2 ^= (1 << i);//翻转偶数位

dfs(ops-1, m2);

int m3 = mask;

for (int i = 0; i < n; i += 2) m3 ^= (1 << i);//奇数位

dfs(ops-1, m3);

int m4 = mask;

++for (int i = 0; i < n; i += 3) m4 ^= (1 << i);//隔3翻转++

dfs(ops-1, m4);

};

presses=min(presses,4);

dfs(presses, init_mask);

return states.size();

}

};

相关推荐
Jay Kay28 分钟前
GVPO:Group Variance Policy Optimization
人工智能·算法·机器学习
Epiphany.55639 分钟前
蓝桥杯备赛题目-----爆破
算法·职场和发展·蓝桥杯
YuTaoShao1 小时前
【LeetCode 每日一题】1653. 使字符串平衡的最少删除次数——(解法三)DP 空间优化
算法·leetcode·职场和发展
茉莉玫瑰花茶1 小时前
C++ 17 详细特性解析(5)
开发语言·c++·算法
cpp_25011 小时前
P10570 [JRKSJ R8] 网球
数据结构·c++·算法·题解
cpp_25011 小时前
P8377 [PFOI Round1] 暴龙的火锅
数据结构·c++·算法·题解·洛谷
uesowys2 小时前
Apache Spark算法开发指导-Factorization machines classifier
人工智能·算法
季明洵2 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
shandianchengzi2 小时前
【小白向】错位排列|图文解释公考常见题目错位排列的递推式Dn=(n-1)(Dn-2+Dn-1)推导方式
笔记·算法·公考·递推·排列·考公
I_LPL2 小时前
day26 代码随想录算法训练营 回溯专题5
算法·回溯·hot100·求职面试·n皇后·解数独