【leetcode】周赛199---(1)1528. 重新排列字符串(2)1529. 灯泡开关 IV_开关问题(3)1530. 好叶子节点对的数量_dfs(4)1531. 压缩字符串 II_dp

这篇博客介绍了LeetCode周赛中的四道题目,包括字符串重新排列、灯泡开关问题、好叶子节点对数量的计算以及行程长度编码的压缩问题。通过DFS解决树的问题,并探讨了不同题目中优化算法和空间复杂度的方法。
摘要由CSDN通过智能技术生成

1528、给你一个字符串 s 和一个 长度相同 的整数数组 indices 。

请你重新排列字符串 s ,其中第 i 个字符需要移动到 indices[i] 指示的位置。

返回重新排列后的字符串。

示例 1:

输入:s = "codeleet", indices = [4,5,6,7,0,2,1,3]
输出:"leetcode"
解释:如图所示,"codeleet" 重新排列后变为 "leetcode" 。

class Solution {
public:
    string restoreString(string s, vector<int>& indices) {
        string ans = s;
        for(int i = 0; i < indices.size(); i++)
            ans[indices[i]] = s[i];
        return ans;
    }
};

结果:

执行用时:16 ms, 在所有 C++ 提交中击败了79.32% 的用户

内存消耗:15.4 MB, 在所有 C++ 提交中击败了26.03% 的用户

 

1529、房间中有 n 个灯泡,编号从 0 到 n-1 ,自左向右排成一行。最开始的时候,所有的灯泡都是 关 着的。

请你设法使得灯泡的开关状态和 target 描述的状态一致,其中 target[i] 等于 1 第 i 个灯泡是开着的,等于 0 意味着第 i 个灯是关着的。

有一个开关可以用于翻转灯泡的状态,翻转操作定义如下:

  1.     选择当前配置下的任意一个灯泡(下标为 i )
  2.     翻转下标从 i 到 n-1 的每个灯泡

翻转时,如果灯泡的状态为 0 就变为 1,为 1 就变为 0 。

返回达成 target 描述的状态所需的 最少 翻转次数。

示例 1:

输入:target = "10111"
输出:3
解释:初始配置 "00000".
从第 3 个灯泡(下标为 2)开始翻转 "00000" -> "00111"
从第 1 个灯泡(下标为 0)开始翻转 "00111" -> "11000"
从第 2 个灯泡(下标为 1)开始翻转 "11000" -> "10111"
至少需要翻转 3 次才能达成 target 描述的状态

简单版的开关问题

class Solution {
public:
    int minFlips(string target) {
        int ans = 0;
        for(int i = 0; i &l
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值