面试题 01.09:字符串轮转

简介: 面试题 01.09:字符串轮转

题目

题目链接

字符串轮转。给定两个字符串s1和s2,请编写代码检查s2是否为s1旋转而成(比如,waterbottle是erbottlewat旋转后的字符串)。

示例1:

输入:s1 = "waterbottle", s2 = "erbottlewat"
 输出:True

示例2:

输入:s1 = "aa", s2 = "aba"
 输出:False

解题

方法一:拼接字符串

1.如果字符串长度不相等,一定不是轮转结果

2.轮转s2+s2拼接后,一定包含s1

class Solution {
public:
    bool isFlipedString(string s1, string s2) {
        if(s1.size()!=s2.size()) return false;
        return (s2+s2).find(s1)!=-1;
    }
};

方法二:模拟

class Solution {
public:
    bool isFlipedString(string s1, string s2) {
        int m=s1.size(),n=s2.size();
        if(m!=n) return false;
        if(m==0) return true;
        for(int i=0;i<m;i++){
            bool flag=true;
            for(int j=0;j<m;j++){
                if(s1[(i+j)%n]!=s2[j]){
                    flag=false;
                    break;
                }
            }
            if(flag) return true;
        }
        return false;
    }
};
相关文章
|
8月前
|
存储
力扣面试经典题之数组/字符串
力扣面试经典题之数组/字符串
60 0
|
5月前
|
安全 Java 编译器
【Java基础面试二十九】、说一说你对字符串拼接的理解
这篇文章讨论了Java中字符串拼接的四种常用方式(使用`+`运算符、`StringBuilder`、`StringBuffer`和`String`类的`concat`方法),每种方式适用的场景,以及在不同情况下的性能考量。
|
5月前
|
Java
【Java基础面试二十八】、使用字符串时,new和““推荐使用哪种方式?
这篇文章讨论了在Java中使用字符串时,推荐使用双引号`""`直接量方式而不是使用`new`操作符,因为`new`会在常量池之外额外创建一个对象,导致更多的内存占用。
|
8月前
|
存储 算法 安全
【刷题】 leetcode 面试题 01.06 字符串压缩
来看效果: 非常好!!!过啦!!!
75 5
【刷题】 leetcode 面试题 01.06 字符串压缩
|
7月前
|
存储 算法 数据挖掘
深入解析力扣166题:分数到小数(模拟长除法与字符串操作详解及模拟面试问答)
深入解析力扣166题:分数到小数(模拟长除法与字符串操作详解及模拟面试问答)
|
6月前
|
存储 安全 Java
Java面试题:请解释Java中的字符串和字符串缓冲区?
Java面试题:请解释Java中的字符串和字符串缓冲区?
40 0
|
8月前
|
索引 Python Go
【python学习】字符串详解,面试必问公司的问题
【python学习】字符串详解,面试必问公司的问题
|
8月前
|
存储 Go 开发者
Golang深入浅出之-Go语言字符串操作:常见函数与面试示例
【4月更文挑战第20天】Go语言字符串是不可变的字节序列,采用UTF-8编码。本文介绍了字符串基础,如拼接(`+`或`fmt.Sprintf()`)、长度与索引、切片、查找与替换(`strings`包)以及转换与修剪。常见问题包括字符串不可变性、UTF-8编码处理、切片与容量以及查找与替换的边界条件。通过理解和实践这些函数及注意事项,能提升Go语言编程能力。
237 0
|
8月前
面试题 01.06. 字符串压缩
面试题 01.06. 字符串压缩
30 0
|
8月前
|
算法 测试技术 索引
力扣面试经典题之数组/字符串(二)
力扣面试经典题之数组/字符串(二)
41 0

热门文章

最新文章