LeetCode题解C++生成每种字符都是奇数个的字符串

 更新时间:2022年10月09日 10:59:17   作者:Junkman丶  
这篇文章主要为大家介绍了LeetCode题解C++生成每种字符都是奇数个的字符串示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

题目描述

题目链接:1374. 生成每种字符都是奇数个的字符串

给你一个整数 n,请你返回一个含 n 个字符的字符串,其中每种字符在该字符串中都恰好出现 奇数次

返回的字符串必须只含小写英文字母。如果存在多个满足题目要求的字符串,则返回其中任意一个即可。

提示:

1 <= n <= 500

示例 1:

输入:n = 4
输出:"pppz"
解释:"pppz" 是一个满足题目要求的字符串,因为 'p' 出现 3 次,且 'z' 出现 1 次。当然,还有很多其他字符串也满足题目要求,比如:"ohhh" 和 "love"。

示例 2:

输入:n = 2
输出:"xy"
解释:"xy" 是一个满足题目要求的字符串,因为 'x' 和 'y' 各出现 1 次。当然,还有很多其他字符串也满足题目要求,比如:"ag" 和 "ur"。

示例 3:

输入: n = 7
输出: "holasss"

整理题意

题目要求我们构造一个长度为 n 的字符串,且字符串中每个字符出现的次数都为奇数次。

题目规定字符串中的字符必须都是小写字母,因为答案不唯一,所以返回任意一个都是可以的。

解题思路分析

由于题目仅要求字符串中的字符都要出现奇数次,那么我们可以直接 分类讨论

  • n 为奇数时,我们直接构造 n 个相同的任意小写字母即可。
  • n 为偶数时,我们可以直接构造 n - 1 个相同的任意小写字母,然后在末尾添加一个与前面不同的任意一个小写字母即可。

具体实现

在构造长度为 n 的字符串时,我们可以直接使用构造函数:string(size_type length, char ch),表示构造长度为 length 的字符串,字符串中每个字符都为 ch,也就是 lengthch 构成的字符串。

写成 string s(n, c); 表示字符串 sn'c' 构成的字符串(s = "ccc...ccc"),而 string(n, c); 是直接返回 n'c' 构成的字符串("ccc...ccc")。

我们还可以直接通过 while 循环来实现构造:while(ans.length() < n) ans += 'c';

复杂度分析

  • 时间复杂度:O(n)。
  • 空间复杂度:O(1)。这里不计入返回值需要的空间。

代码实现

class Solution {
public:
    string generateTheString(int n) {
        // string(size_type length, char ch);
        // 以length为长度的ch的拷贝(即length个ch)
        if(n & 1) return string(n, 'a');
        else return string(n - 1, 'a') + 'b';
    }
};

总结

  • 该题较为简单,仅需分类讨论然后直接构造即可,分为构造长度为奇数和偶数两种情况。
  • 该题所新学到的构造函数:string(size_type length, char ch),表示 lengthch 构成的字符串。同时还可以在声明字符串时用到,例如:string s(length, ch);,这就表示构造的字符串赋值到一个变量 s 上了。

测试结果:

以上就是LeetCode题解C++生成每种字符都是奇数个的字符串的详细内容,更多关于C++奇数字符串的资料请关注脚本之家其它相关文章!

相关文章

  • 基于Qt实现Android的图案密码效果

    基于Qt实现Android的图案密码效果

    这篇文章主要为大家详细介绍了如何基于Qt实现Android的图案密码效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下
    2024-12-12
  • 用C语言实现简单五子棋小游戏

    用C语言实现简单五子棋小游戏

    这篇文章主要为大家详细介绍了用C语言实现简单五子棋小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • C++中内存池和内存分配区Arena概念详解

    C++中内存池和内存分配区Arena概念详解

    在 C++ 中,内存分配区(Arena)通常指的是预先分配的一大块连续内存空间,这种方法的主要目的是提高内存分配和释放的效率,下面就跟随小编一起了解一下C++中内存池和内存分配区Arena相关概念吧
    2023-12-12
  • C语言背包问题求解全过程(贪心方法)

    C语言背包问题求解全过程(贪心方法)

    背包问题是一个经典的动态规划问题,而贪心算法是一种常用的解决背包问题的方法,这篇文章主要给大家介绍了关于C语言背包问题求解(贪心方法)的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-06-06
  • C语言结构体指针的具体使用

    C语言结构体指针的具体使用

    结构体指针是一种非常有用的数据类型,它可以让我们更方便地操作结构体,本文主要介绍了C语言结构体指针的具体使用,非常具有实用价值,需要的朋友可以参考下
    2023-05-05
  • C语言实现简单图书管理系统

    C语言实现简单图书管理系统

    这篇文章主要为大家详细介绍了C语言实现图书管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • C 二分查找 递归与非递归的实现代码

    C 二分查找 递归与非递归的实现代码

    C 二分查找 递归与非递归的实现代码,需要的朋友可以参考一下
    2013-03-03
  • Matlab绘制雨云图的方法详解

    Matlab绘制雨云图的方法详解

    这篇文章主要介绍了如何利用Matlab实现雨云图的绘制,文中的示例代码讲解详细,对我们学习Matlab有一定的帮助,需要的可以参考一下
    2022-05-05
  • C++求所有顶点之间的最短路径(用Floyd算法)

    C++求所有顶点之间的最短路径(用Floyd算法)

    这篇文章主要为大家详细介绍了C++求所有顶点之间的最短路径,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • 树形结构的3中搜索方式示例分享

    树形结构的3中搜索方式示例分享

    树的3中常见搜索方式,包括二叉树方式(每一层只有0和1)、满m叉树(每一层都有0 到m - 1)、子集树,也称为全排列树,需要的朋友可以参考下
    2014-02-02

最新评论