【每日刷题】Day165

【每日刷题】Day165

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

[1. LCR 092. 将字符串翻转到单调递增 - 力扣(LeetCode)](#1. LCR 092. 将字符串翻转到单调递增 - 力扣(LeetCode))

[2. 424. 替换后的最长重复字符 - 力扣(LeetCode)](#2. 424. 替换后的最长重复字符 - 力扣(LeetCode))

[3. 1812. 判断国际象棋棋盘中一个格子的颜色 - 力扣(LeetCode)](#3. 1812. 判断国际象棋棋盘中一个格子的颜色 - 力扣(LeetCode))

1. LCR 092. 将字符串翻转到单调递增 - 力扣(LeetCode)

//思路:动态规划

class Solution {

public:

int minFlipsMonoIncr(string s)

{

int n = s.size(),ans = 2000001;

vector<vector<int>> dp(n,vector<int>(2));

if(s[0]=='0') dp[0][1] = 1;//初始化

else dp[0][0] = 1;

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

{

dp[i][0] = s[i]=='0'?dp[i-1][0]:dp[i-1][0]+1;//填表

dp[i][1] = min(dp[i-1][0],s[i]=='1'?dp[i-1][1]:dp[i-1][1]+1);

}

return min(dp[n-1][0],dp[n-1][1]);

}

};

2. 424. 替换后的最长重复字符 - 力扣(LeetCode)

//思路:滑动窗口

class Solution {

public:

int characterReplacement(string s, int k)

{

int n = s.size();

int hash[27] = {0};

int left = 0,right = 0,max = 0,ans = 0;

while(right<n)

{

int ch = s[right]-'A';

hash[ch]++;

max = max>hash[ch]?max:hash[ch];//记录窗口内出现次数最多的元素的个数

if(right-left+1-max>k)

{

ans = ans>right-left?ans:(right-left);//记录最大窗口长度

hash[s[left++]-'A']--;

}

right++;

}

ans = ans>right-left?ans:(right-left);

return ans;

}

};

3. 1812. 判断国际象棋棋盘中一个格子的颜色 - 力扣(LeetCode)

//思路:找规律

//放松题

class Solution {

public:

bool squareIsWhite(string c)

{

int hash[8] = {1,2,3,4,5,6,7,8};

int ret1 = hash[c[0]-'a']%2,ret2 = (c[1]-'0')%2;

if((ret1&&ret2)||(!ret1&&!ret2)) return false;

return true;

}

}

相关推荐
芒果爱编程2 小时前
MCU、ARM体系结构,单片机基础,单片机操作
开发语言·网络·c++·tcp/ip·算法
再不会python就不礼貌了2 小时前
震撼!最强开源模型通义千问2.5 72B竟在4GB老显卡上成功运行!
人工智能·算法·机器学习·chatgpt·产品经理
工业甲酰苯胺5 小时前
C语言之输入输出
c语言·c++·算法
C++忠实粉丝6 小时前
计算机网络之NAT、代理服务、内网穿透、内网打洞
网络·c++·网络协议·计算机网络·http·智能路由器
零光速6 小时前
数据处理与统计分析——10-Pandas可视化-Matplotlib的常用API
数据结构·python·数据分析·pandas·matplotlib
努力d小白6 小时前
leetcode98.验证二叉搜索树
算法
YueTann6 小时前
Leetcode SQL 刷题与答案-基础篇
sql·算法·leetcode
归寻太乙6 小时前
算法基础Day7(动态规划)
算法·动态规划
片片叶6 小时前
C++(十四)
开发语言·c++
hn小菜鸡7 小时前
LeetCode 2320.统计放置房子的方式数
算法·leetcode·职场和发展