一、题目描述
给定一个非空的字符串s
,检查是否可以通过由它的一个子串重复多次构成。
示例 1
输入: s = "abab"
输出: true
解释: 可由子串"ab"
重复两次构成。
示例 2
输入: s = "aba"
输出: false
示例 3
输入: s = "abcabcabcabc"
输出: true
解释: 可由子串"abc"
重复四次构成。(或子串"abcabc"
重复两次构成。)
给定一个非空的字符串s
,检查是否可以通过由它的一个子串重复多次构成。
示例 1
输入: s = "abab"
输出: true
解释: 可由子串"ab"
重复两次构成。
示例 2
输入: s = "aba"
输出: false
示例 3
输入: s = "abcabcabcabc"
输出: true
解释: 可由子串"abc"
重复四次构成。(或子串"abcabc"
重复两次构成。)
给你两个字符串haystack
和needle
,请你在haystack
字符串中找出needle
字符串的第一个匹配项的下标(下标从0
开始)。如果needle
不是haystack
的一部分,则返回 -1
。
示例 1
输入: haystack = "sadbutsad", needle = "sad"
输出: 0
解释: "sad"
在下标0
和6
处匹配。第一个匹配项的下标是0
,所以返回0
。
字符串的右旋转操作是把字符串尾部的若干个字符转移到字符串的前面。给定一个字符串s
和一个正整数k
,请编写一个函数,将字符串中的后面k
个字符移到字符串的前面,实现字符串的右旋转操作。
例如,对于输入字符串"abcdefg"
和整数2
,函数应该将其转换为"fgabcde"
。
示例 1
输入: k = 2, s = "abcdefg"
输出: "fgabcde"
给你一个字符串s
,请你反转字符串中单词的顺序。
单词是由非空格字符组成的字符串。s
中使用至少一个空格将字符串中的单词分隔开。
返回单词顺序颠倒且单词之间用单个空格连接的结果字符串。
注意:输入字符串s
中可能会存在前导空格、尾随空格或者单词间的多个空格。返回的结果字符串中,单词间应当仅用单个空格分隔,且不包含任何额外的空格。
给定一个字符串s
,它包含小写字母和数字字符,请编写一个函数,将字符串中的字母字符保持不变,而将每个数字字符替换为number
。 例如,对于输入字符串"a1b2c3"
,函数应该将其转换为"anumberbnumbercnumber"
。
示例 1
输入: a1b2c3
输出: anumberbnumbercnumber
提示
1 <= s.length < 10000
给定一个字符串s
和一个整数k
,从字符串开头算起,每计数至2k
个字符,就反转这2k
字符中的前k
个字符。
k
个,则将剩余字符全部反转。2k
但大于或等于k
个,则反转前k
个字符,其余字符保持原样。示例 1
输入: "abcdefg", k = 2
输出: "bacdfeg"
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组s
的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组,使用O(1)
的额外空间解决这一问题。
示例 1
输入: s = ["h", "e", "l", "l", "o"]
输出: ["o", "l", "l", "e", "h"]