LeetCode 0796.旋转字符串:暴力模拟

【LetMeFly】796.旋转字符串:暴力模拟

力扣题目链接:https://leetcode.cn/problems/rotate-string/

给定两个字符串, sgoal。如果在若干次旋转操作之后,s 能变成 goal ,那么返回 true

s旋转操作 就是将 s 最左边的字符移动到最右边。

  • 例如, 若 s = 'abcde',在旋转一次之后结果就是'bcdea'

示例 1:

复制代码
输入: s = "abcde", goal = "cdeab"
输出: true

示例 2:

复制代码
输入: s = "abcde", goal = "abced"
输出: false

提示:

  • 1 <= s.length, goal.length <= 100
  • sgoal 由小写英文字母组成

解题方法:暴力模拟

如果两个字符串不等长,则直接返回false。否则(就不需要担心下标越界的问题了)假设字符串长度为 n n n:

共计进行 n n n次匹配,使用一个变量 d i f f diff diff从 0 0 0到 n − 1 n-1 n−1枚举,若存在某个 d i f f diff diff可以使得 s ( i + d i f f ) m o d    n s(i+diff)\\mod n s(i+diff)modn和 g o a l i goali goali全部相等,则返回true

否则返回false

  • 时间复杂度 O ( l e n ( s ) 2 ) O(len(s)^2) O(len(s)2)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
cpp 复制代码
/*
 * @LastEditTime: 2026-05-03 17:22:50
 */
class Solution {
private:
    int n;

    bool ok(const string& s, const string& goal, int diff) {
        for (int i = 0; i < n; i++) {
            if (s[(i + diff) % n] != goal[i]) {
                return false;
            }
        }
        return true;
    }
public:
    bool rotateString(const string& s, const string& goal) {
        n = s.size();
        if (goal.size() != n) {
            return false;
        }
        for (int i = 0; i < n; i++) {
            if (ok(s, goal, i)) {
                return true;
            }
        }
        return false;
    }
};
cpp 复制代码
/*
 * @LastEditTime: 2022-04-07 08:13:46
 */
class Solution {
public:
    bool rotateString(string s, string goal) {
        if (s.size() != goal.size())
            return false;
        for (int i = 0; i < s.size(); i++) {
            bool same = true;
            for (int j = 0; j < s.size(); j++) {
                if (s[j] != goal[(i + j) % s.size()]) {
                    same = false;
                    break;
                }
            }
            if (same)
                return true;
        }
        return false;
    }
};

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
AI科技星16 分钟前
基于32维Cayley_Dickson超复数的全域拓扑统一场论——反重力、真空自持供能、维度瞬移与星际宇宙脑秩序体系
人工智能·学习·算法·机器学习·数据挖掘
aichitang202423 分钟前
数论变换(NTT)
c++·算法·fft·ntt
_olone26 分钟前
AtCoder Beginner Contest 465 D - X to Y
c++·算法
青山木30 分钟前
Hot 100 --- LRU 缓存
java·数据结构·算法·leetcode·链表·缓存·哈希
“码”力全开31 分钟前
ONVIF摄像头接入项目实战记录
人工智能·算法·边缘计算
AI科技星1 小时前
公理化数学化学|48小时确权终稿(完整投产包)
人工智能·数学·算法·重构·拓扑学·乖乖数学·全域数学
想你依然心痛1 小时前
AtomCode在算法竞赛中的实战体验:LeetCode周赛辅助编程
linux·算法·leetcode
SilentSamsara1 小时前
模型部署方案选型:REST/gRPC/批量推理/边缘部署的场景决策
人工智能·深度学习·算法·机器学习
zzz_23681 小时前
【Java实习面试算法冲刺】哈希!
java·算法·面试
大耳朵糊涂1 小时前
找前/后驱节点
算法