zoukankan      html  css  js  c++  java
  • 剑指Offer-43.左旋转字符串(C++/Java)

    题目:

    汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!

    分析:

    对一个字符串实现移位操作,在这里我们不使用拼接的方法来做,仅使用翻转来完成。

    根据所给的左移位数K将字符串分成两部分,分别对两个部分进行翻转。

    例如:S=”abcXYZdef”,K=3,分成s1=“abc”和s2=“XYZdef”,将这个两部分翻转后得到s1‘=“cba”和s2’=“fedZYX”,那么现在的s便是“cbafedZYX”,不难发现,此时的s与最终答案“XYZdefabc”,就差了整体再翻转一次。所以,这道题的答案,便是通过K,将字符串的两部分分别进行翻转,最后再对整体进行一次翻转即可。

    程序:

    C++

    class Solution {
    public:
        string LeftRotateString(string str, int n) {
            if(str.size() == 0)
                return str;
            n %= str.size();
            myReverse(str, 0, n-1);
            myReverse(str, n, str.size()-1);
            myReverse(str, 0, str.size()-1);
            return str;
        }
        void myReverse(string &str, int l, int r){
            if(l > str.size()-1 || r < 0)
                return;
            while(l < r){
                swap(str[l], str[r]);
                l++;
                r--;
            }
        }
    };

    Java

    public class Solution {
        public String LeftRotateString(String str, int n) {
            if(str.length() == 0)
                return str;
            StringBuilder s = new StringBuilder(str);
            n %= str.length();
            myReverse(s, 0, n-1);
            myReverse(s, n, s.length()-1);
            myReverse(s, 0, s.length()-1);    
            return s.toString();
        }
        public static void myReverse(StringBuilder str, int l, int r) {
            if(r < 0 || l > str.length()-1)
                return;
            while(l < r) {
                swap(str, l, r);
                l++;
                r--;
            }
        }
        public static void swap(StringBuilder str, int l, int r) {
            char temp = str.charAt(l);
            str.setCharAt(l, str.charAt(r));
            str.setCharAt(r, temp);
        }
    }
  • 相关阅读:
    C++_构造函数与析构函数
    华为模拟机试_C++题解
    OOP_由C到C++
    OOP_面向对象程序设计概述
    java ssm 后台框架平台 项目源码 websocket即时聊天发图片文字 好友群组 SSM源码
    springmvc SSM 多数据源 shiro redis 后台框架 整合
    【面经】5年Java面试亲身经验
    【快手初面】要求3个线程按顺序循环执行,如循环打印A,B,C
    手工实现HttpBasic校验
    Java 并发系列(一) ThreadPoolExecutor源码解析及理解
  • 原文地址:https://www.cnblogs.com/silentteller/p/12069702.html
Copyright © 2011-2022 走看看