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();

}

};

相关推荐
hans汉斯1 分钟前
国产生成式人工智能解决物理问题能力研究——以“智谱AI”、“讯飞星火认知大模型”、“天工”、“360智脑”、“文心一言”为例
大数据·人工智能·算法·aigc·文心一言·汉斯出版社·天工
v_for_van4 分钟前
力扣刷题记录3(无算法背景,纯C语言)
c语言·算法·leetcode
ValhallaCoder8 分钟前
hot100-矩阵
数据结构·python·算法·矩阵
散峰而望9 分钟前
【基础算法】穷举的艺术:在可能性森林中寻找答案
开发语言·数据结构·c++·算法·随机森林·github·动态规划
心.c11 分钟前
Vue3+Node.js实现文件上传分片上传和断点续传【详细教程】
前端·javascript·vue.js·算法·node.js·哈希算法
散峰而望11 分钟前
【基础算法】算法的“预谋”:前缀和如何改变游戏规则
开发语言·数据结构·c++·算法·github·动态规划·推荐算法
We་ct12 分钟前
LeetCode 48. 旋转图像:原地旋转最优解法
前端·算法·leetcode·typescript
爱尔兰极光12 分钟前
LeetCode--长度最小的子数组
算法·leetcode·职场和发展
仰泳的熊猫14 分钟前
题目1432:蓝桥杯2013年第四届真题-剪格子
数据结构·c++·算法·蓝桥杯·深度优先·图论
有一个好名字20 分钟前
力扣-电话号码组合
算法·leetcode·职场和发展