【每日刷题】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;

}

}

相关推荐
leoufung7 分钟前
LeetCode 67. Add Binary:从面试思路到代码细节
算法·leetcode·面试
无限进步_16 分钟前
【C语言】循环队列的两种实现:数组与链表的对比分析
c语言·开发语言·数据结构·c++·leetcode·链表·visual studio
qq_3106585116 分钟前
webrtc源码走读(四)核心引擎层——视频引擎
服务器·c++·音视频·webrtc
wjykp21 分钟前
79~87逻辑回归f
算法·机器学习·逻辑回归
何包蛋H26 分钟前
数据结构深度解析:Java Map 家族完全指南
java·开发语言·数据结构
码界奇点31 分钟前
基于React与TypeScript的后台管理系统设计与实现
前端·c++·react.js·typescript·毕业设计·源代码管理
社会零时工32 分钟前
【ROS2】海康相机ROS2设备服务节点开发
linux·c++·相机·ros2
古译汉书33 分钟前
keil编译错误:Error: Flash Download failed
开发语言·数据结构·stm32·单片机·嵌入式硬件
Bruce_kaizy34 分钟前
2025年年度总结!!!!!!!!!!!!!!!!!!!!!!!!!!!
开发语言·c++
聆风吟º35 分钟前
【顺序表习题|图解|双指针】合并两个有序数组 + 训练计划 I
c语言·数据结构·c++·经验分享·算法