zoukankan      html  css  js  c++  java
  • 翻转单词顺序(左旋转字符串)

    题目

      输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。为简单起见,标点符号和普通字母一样处理。例如输入字符串"I am a student.",则输出"student. a am I"。

    思路

    1. 翻转句子中所有的字符。比如翻转"I am a student."中所有的字符得到".tneduts a ma I",此时不但翻转了句子中单词的顺序,连单词内的字符顺序也被翻转了。
    2. 再翻转每个单词中字符的顺序,就得到了"student.a am I"。这正是符合题目要求的输出。
    class Solution {
    public:
        string ReverseSentence(string str) {
            if(str.empty())
                return "";
            
            reverses(str,0,str.size()-1);
            int i=0,j=0;
            while(j<=str.size())
            {
                if(str[i]==' ')
                {
                    ++i;
                    ++j;
                }
                else if(str[j]==' '||str[j]=='')
                {
                    reverses(str,i,j-1);
                    ++j;
                    i=j;
                }
                else
                    ++j;
            }
            return str;
        }
    private:
        void reverses(string &str,int i,int j)
        {
            while(i<j)
            {
                swap(str[i],str[j]);
                ++i;
                --j;
            }
            return ;
        }
    };

    题目

      字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如输入字符串"abcdefg"和数字2,该函数将返回左旋转2位得到的结果"cdefgab"。

    思路

      以"abcdefg"为例,我们可以把它分为两部分。由于想把它的前两个字符移到后面,我们就把前两个字符分到第一部分,把后面的所有字符都分到第二部分。我们先分别翻转这两部分,于是就得到"bagfedc"。接下来我们再翻转整个字符串,得到的"cdefgab"刚好就是把原始字符串左旋转2位的结果。

    #include <iostream>
    #include <algorithm>
    using namespace std;
    
    class Solution
    {
        public:    
            void left_roate_string(string &s,const int &n);
            void reverse(string::iterator begin,string::iterator end);
    };
    void Solution::left_roate_string(string &s,const int &n)
    {
        if(s.empty()||s.length()<=0)
            return;
        
        string::iterator first_begin=s.begin();
        string::iterator first_end=s.begin()+n-1;
        string::iterator second_begin=s.begin()+n;
        string::iterator second_end=--s.end();
        
        reverse(first_begin,first_end);
    /*    for(auto it=first_begin;it<=first_end;++it)
            cout<<*it;*/
        reverse(second_begin,second_end);
        /*for(auto it=second_begin;it<=second_end;++it)
            cout<<*it;
        cout<<endl;*/
        reverse(first_begin,second_end);
    }
    void Solution::reverse(string::iterator begin,string::iterator end)
    {
        while(begin<end)
        {
            swap(*begin,*end);
            ++begin;
            --end;
        }
    }
    int main()
    {
        Solution s;
        string str("abcdefg");
        s.left_roate_string(str,2);
        cout<<str<<endl;
        return 0;
    }

     左旋转字符串

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

    class Solution {
    public:
        string LeftRotateString(string str, int n) {
            if(str.empty()||n<0)
                return "";
            
            n%=str.size();
            reverse(str.begin(),str.end());
            reverse(str.begin(),str.begin()+str.size()-n);
            reverse(str.begin()+str.size()-n,str.end());
            return str;
        }
    };
  • 相关阅读:
    初学者之 Git 和 Github
    80端口与8080端口是两种不同的端口吗?他们到底有什么区别和联系?
    redis 基础(一) 初步了解redis
    spring 基础(四)浏览器跨域访问+拦截器(Interceptor)
    mysql商业版和社区版
    spring 基础(五) spring mvc RESTful
    解决idea控制台打印乱码问题
    springBoot 基础-拓展(二) 记录一些常用的配置文件
    SpringBoot 基础(零) SpringBoot和Spring
    springBoot 基础-拓展(一) spring-boot-starter
  • 原文地址:https://www.cnblogs.com/tianzeng/p/10305297.html
Copyright © 2011-2022 走看看