20200814:力扣201周周赛题解记录上

力扣201周周赛题解记录上

题目

  1. 整理字符串

在这里插入图片描述
在这里插入图片描述

  1. 找出第 N 个二进制字符串中的第 K 位
    在这里插入图片描述

思路与算法

  1. 第一题这种类似消消乐的东西都是直接用栈来实现的,注意代码细节
  2. 第二题也是一个可以直接按照题意暴力模拟的题目,实现他所提到的invert函数即可。
  3. 记录一下,今天开始加更最近研一开学之前的缺的点专业课知识,涉及信号系统,通信原理,以及数字信号处理的内容。保持细节

代码实现

  1. 整理字符串
class Solution {
    public String makeGood(String s) {
    
        Stack<Character> stack = new Stack<Character>();
        char[] ch = s.toCharArray();
        for (int i = 0; i < ch.length; i++) {
            
            if (stack.isEmpty()) {
                stack.push(ch[i]);
                continue;
            } 
            char tmp = stack.peek();
            if (tmp - ch[i] == 32 || tmp - ch[i] == -32) {
                stack.pop();
            } else {
                stack.push(ch[i]);
            }
            
        }

        StringBuilder sb = new StringBuilder();
        for (Character s1 : stack) {
            sb.append(s1);
        }

        return sb.toString();
    }
}
  1. 找出第 N 个二进制字符串中的第 K 位
package com.immunize.leetcode.findKthBit;

public class Solution {
	public char findKthBit(int n, int k) {
		// 产生这个Sn
		String s = generateString(n);
		// 返回Sn的第k个值返回即可
		return s.charAt(k - 1);
	}

	private String generateString(int n) {
		String[] sn = new String[n];
		sn[0] = "0";
		for (int i = 1; i < n; i++) {
			sn[i] = sn[i - 1] + "1" + reverse(invert(sn[i - 1]));
		}
		return sn[n - 1];
	}

	private String reverse(String invert) {
		StringBuilder sb = new StringBuilder();
		return sb.append(invert).toString();
	}

	private String invert(String sn) {
		StringBuilder sb = new StringBuilder();
		for (int i = 0; i < sn.length(); i++) {
			if (sn.charAt(i) == '1') {
				sb.append('0');
			} else {
				sb.append('1');
			}
		}
		return sb.toString();
	}
}

写在最后

更新博客的目的是为了记录自己的学习情况,以做到学而时习之,切忌本末倒置。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IMMUNIZE

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值