LeetCode 482 秘钥格式化[模拟 字符串] HERODING的LeetCode之路

Posted HERODING23

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 482 秘钥格式化[模拟 字符串] HERODING的LeetCode之路相关的知识,希望对你有一定的参考价值。


解题思路:
一道非常简单的字符串模拟题,为了保证均分,允许第一个区间不是满的(小于等于k),那么我们可以倒着来,每k个放入一个区间,然后加上‘-’,如果完全均分,要注意把最后的‘-’给删除掉,最后倒过来返回即可,代码如下:

class Solution {
public:
    string licenseKeyFormatting(string s, int k) {
        int len = s.size();
        string ans = "";
        int count = 0;
        for(int i = len - 1; i >= 0; i --) {
            if(s[i] == '-') {
                continue;
            } else {
                ans.push_back(toupper(s[i]));
                count ++;
                if(count == k) {
                    count = 0;
                    ans += "-";
                }
            }
        }
        if(ans.size() > 0 && ans.back() == '-') {
            ans.pop_back();
        }
        reverse(ans.begin(), ans.end());
        return ans;
    }
};

以上是关于LeetCode 482 秘钥格式化[模拟 字符串] HERODING的LeetCode之路的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode482 密钥格式化

Leetcode之482.密钥格式化

Leetcode刷题100天—482. 密钥格式化(字符)—day57

Leetcode刷题100天—482. 密钥格式化(字符)—day57

482. 密钥格式化

[LeetCode] 482. License Key Formatting 注册码格式化