​力扣解法汇总481. 神奇字符串

目录链接:

力扣编程题-解法汇总_分享+记录-CSDN博客

GitHub同步刷题项目:

https://github.com/September26/java-algorithms

原题链接:力扣


描述:

神奇字符串 s 仅由 '1' 和 '2' 组成,并需要遵守下面的规则:

  • 神奇字符串 s 的神奇之处在于,串联字符串中 '1' 和 '2' 的连续出现次数可以生成该字符串。

s 的前几个元素是 s = "1221121221221121122……" 。如果将 s 中连续的若干 1 和 2 进行分组,可以得到 "1 22 11 2 1 22 1 22 11 2 11 22 ......" 。每组中 1 或者 2 的出现次数分别是 "1 2 2 1 1 2 1 2 2 1 2 2 ......" 。上面的出现次数正是 s 自身。

给你一个整数 n ,返回在神奇字符串 s 的前 n 个数字中 1 的数目。

示例 1:

输入:n = 6
输出:3
解释:神奇字符串 s 的前 6 个元素是 “122112”,它包含三个 1,因此返回 3 。 

示例 2:

输入:n = 1
输出:1

提示:

  • 1 <= n <= 105

解题思路:

* 解题思路:
* 首先,使用两个标记位来记录使用到的位置和插入的位置。
* 前两个字符先用硬编码的方式写入,第三个字符开始,判断最末端的两个字符类型,一共有四种,11,12,21,22,
* 然后结合插入1个还是2个字符,进行插入,并记录插入的1的数量。

代码:

public class Solution481 {
    int num1Sum = 0;

    public int magicalString(int n) {
        int insertIndex = 0;
        int useIndex = 0;

        StringBuilder builder = new StringBuilder();
        while (true) {
            if (builder.length() == 0) {
                builder.append("1");
                insertIndex++;
                num1Sum++;
                continue;
            }
            if (builder.length() == 1) {
                builder.append("2");
                insertIndex++;
                useIndex++;
                continue;
            }
            String lastStr = builder.substring(builder.length() - 2, builder.length());
            char useChar = builder.charAt(useIndex);
            insertIndex = insertChar(builder, lastStr, useChar, insertIndex);
            useIndex++;
            if (insertIndex == n) {
                break;
            }
            if (insertIndex > n) {
                if (builder.charAt(builder.length() - 1) == '1') {
                    num1Sum--;
                }
                break;
            }
        }
        return num1Sum;
    }

    /**
     * @return
     */
    private int insertChar(StringBuilder builder, String lastStr, char useChar, int insertIndex) {
        //插入1个
        if (useChar == '1') {
            if (lastStr.equals("11")) {
                builder.append('2');
            } else if (lastStr.equals("12")) {
                builder.append('1');
                num1Sum += 1;
            } else if (lastStr.equals("21")) {
                builder.append('2');
            } else if (lastStr.equals("22")) {
                builder.append('1');
                num1Sum += 1;
            }
            return insertIndex + 1;
        }
        //插入2个
        if (lastStr.equals("11")) {
            builder.append("22");
        } else if (lastStr.equals("12")) {
            builder.append("21");
            num1Sum += 1;
        } else if (lastStr.equals("21")) {
            builder.append("12");
            num1Sum += 1;
        } else if (lastStr.equals("22")) {
            builder.append("11");
            num1Sum += 2;
        }
        return insertIndex + 2;
    }

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

失落夏天

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

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

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

打赏作者

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

抵扣说明:

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

余额充值