【Leetcode -342. 4的幂 -344.反转字符串 -345.反转字符串中的元音字母】

简介: 【Leetcode -342. 4的幂 -344.反转字符串 -345.反转字符串中的元音字母】

Leetcode -342. 4的幂

题目:给定一个整数,写一个函数来判断它是否是 4 的幂次方。如果是,返回 true ;否则,返回 false 。

整数 n 是 4 的幂次方需满足:存在整数 x 使得 n == 4x

示例 1:

输入:n = 16

输出:true

示例 2:

输入:n = 5

输出:false

示例 3:

输入:n = 1

输出:true

提示:

  • 2^31 <= n <= 2^31 - 1
  1. 循环法

循环法的思路是,将n一直取余数,如果不为0,则说明不是4的幂,跳出循环,返回false;若为0,则取n的商,继续进入循环判断;直到n一直取商后取余不为0,或者最后n变成1;n变成1之后,则说明n是4的幂;

bool isPowerOfFour(int n)
    {
        if (n <= 0)
            return false;
        while (!(n % 4))
            n /= 4;
        if (n == 1)
            return true;
        else
            return false;
    }
  1. 二进制表示中 1 的位置

我们的思路是,4的幂二进制中,1都是在偶数位上,其他都是0,所以如果是4的幂,按位与上0xaaaaaaaa,结果就是0;但在这个条件之前的前提是n>0并且n是2的幂;

bool isPowerOfFour(int n)
    {
        //首先大于0;并且满足是2的幂;最后按位与上所有偶数二进制位都是 0,所有奇数二进制位都是1的数,即十六进制的0xaaaaaaaa
        //4的幂二进制数中,1都是在偶数位上,其他都是0,所以如果是4的幂,按位与上0xaaaaaaaa,结果就是0
        return n > 0 && (n & (n - 1)) == 0 && (n & 0xaaaaaaaa) == 0;
    }

Leetcode -344.反转字符串

题目:编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。

不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

示例:

输入:s = [“h”, “e”, “l”, “l”, “o”]

输出:[“o”, “l”, “l”, “e”, “h”]

我们的思路是双指针,左指针下标从0开始,右指针下标从数组长度-1开始遍历,每交换一次左指针++,右指针- -,直到左指针大于右指针;

void reverseString(char* s, int sSize)
    {
        //左指针下标从0开始,右指针下标从数组长度-1开始
        int left = 0, right = sSize - 1;
        //当左指针比右指针的值小,循环继续
        while (left < right)
        {
            char tmp = s[left];
            s[left] = s[right];
            s[right] = tmp;
            left++;
            right--;
        }
    }

Leetcode -345.反转字符串中的元音字母

题目:给你一个字符串 s ,仅反转字符串中的所有元音字母,并返回结果字符串。

元音字母包括 ‘a’、‘e’、‘i’、‘o’、‘u’,且可能以大小写两种形式出现不止一次。

示例 1:

输入:s = “hello”

输出:“holle”

示例 2:

输入:s = “leetcode”

输出:“leotcede”

我们的思路是双指针,左指针下标从0开始,右指针下标从数组长度-1开始,两个指针都从两边开始找元音字母,两个都找到就交换,否则继续找;

bool isvowel(char ch)
    {
        //创建一个元音字母的数组
        char vowel[] = "aeiouAEIOU";
        //遍历元音字母的数组
        for (int i = 0; vowel[i]; i++)
        {
            if (ch == vowel[i])
            {
                //找到返回true
                return true;
            }
        }
        //否则返回false
        return false;
    }
    char* reverseVowels(char* s)
    {
        //左指针下标从0开始,右指针下标从数组长度-1开始
        int left = 0, right = strlen(s) - 1;
        //当左指针比右指针的值小,循环继续
        while (left < right)
        {
            //左指针找元音字母,左指针要在数组长度范围内找
            //进入isvowel函数判断是否元音字母,
            //若返回true证明是元音字母,取非,变成false,就跳出循环;
            //即找到元音字母就跳出循环,否则继续找;
            while (left < strlen(s) && !isvowel(s[left]))
            {
                left++;
            }
            //右指针同理
            while (right > 0 && !isvowel(s[right]))
            {
                right--;
            }
            //当左指针比右指针值小时,交换
            if (left < right)
            {
                char tmp = s[left];
                s[left] = s[right];
                s[right] = tmp;
                left++;
                right--;
            }
        }
        return s;
    }
目录
相关文章
|
10月前
|
存储 算法 Go
【LeetCode 热题100】17:电话号码的字母组合(详细解析)(Go语言版)
LeetCode 17题解题思路采用回溯算法,通过递归构建所有可能的组合。关键点包括:每位数字对应多个字母,依次尝试;递归构建下一个字符;递归出口为组合长度等于输入数字长度。Go语言实现中,使用map存储数字到字母的映射,通过回溯函数递归生成组合。时间复杂度为O(3^n * 4^m),空间复杂度为O(n)。类似题目包括括号生成、组合、全排列等。掌握回溯法的核心思想,能够解决多种排列组合问题。
442 11
|
11月前
|
Go 索引
【LeetCode 热题100】394:字符串解码(详细解析)(Go语言版)
本文详细解析了 LeetCode 热题 394:字符串解码。题目要求对编码字符串如 `k[encoded_string]` 进行解码,其中 `encoded_string` 需重复 `k` 次。文章提供了两种解法:使用栈模拟和递归 DFS,并附有 Go 语言实现代码。栈解法通过数字栈与字符串栈记录状态,适合迭代;递归解法则利用函数调用处理嵌套结构,代码更简洁。两者时间复杂度均为 O(n),但递归需注意栈深度问题。文章还总结了解题注意事项及适用场景,帮助读者更好地掌握字符串嵌套解析技巧。
326 6
|
存储 机器学习/深度学习 缓存
🚀 力扣热题 394:字符串解码(详细解析)(Go语言版)
文章提供了两种解法:栈结构和递归解法。栈解法通过维护数字栈与字符串栈,依次处理 `[` 和 `]`,构造解码结果;递归解法则利用函数调用逐层解析嵌套结构。两者时间复杂度均为 $O(n)$,空间复杂度也为 $O(n)$。栈解法直观易懂,适合初学者;递归解法优雅简洁,适合处理深度嵌套规则。掌握这两种方法,可灵活应对类似问题,提升解题能力。
406 11
|
C++
Leetcode第43题(字符串相乘)
本篇介绍了一种用C++实现的字符串表示的非负整数相乘的方法,通过逆向编号字符串,将乘法运算转化为二维数组的累加过程,最后处理进位并转换为字符串结果,解决了两个大数相乘的问题。
147 9
|
JavaScript
力扣3333.找到初始输入字符串Ⅱ
【10月更文挑战第9天】力扣3333.找到初始输入字符串Ⅱ
205 1
|
存储
Leetcode第49题(字母异位词分组)
LeetCode第49题要求将字符串数组中的字母异位词分组,可以通过将每个字符串排序后作为键存入哈希表,最后将哈希表中的值添加到结果列表中来实现。
167 1
|
算法
【LeetCode 52】17.电话号码的字母组合
【LeetCode 52】17.电话号码的字母组合
181 0
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
385 6
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
211 6
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
463 2