剑指offer:左旋转字符串
2017-04-21 15:45
113 查看
题目描述
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它!//字符串循环左移 //二次翻转 class Solution { public: string LeftRotateString(string str, int n) { //先对整个字符串进行翻转 int size = str.size(); Reversestr(str, 0, size - 1); //再对每一部分分别进行翻转 //翻转0 - size-n-1 Reversestr(str, 0, size - n - 1); //翻转size-n - size-1 Reversestr(str, size - n, size - 1); return str; } void Reversestr(string &str, int start, int end) { while (start <= end) { int temp = str[start]; str[start++] = str[end]; str[end--] = temp; } } };
相关文章推荐
- 《剑指Offer》学习笔记--面试题42:翻转单词顺序VS坐旋转字符串
- 剑指offer之左旋转字符串
- 剑指offer系列源码-左旋转字符串
- 剑指Offer面试题:34.翻转单词顺序VS左旋转字符串
- 剑指Offer详解之左旋转字符串
- 《剑指offer》-左旋转字符串
- 剑指offer(四十二)之左旋转字符串
- 《剑指offer》——左旋转字符串
- 剑指offer系列之四十五:左旋转字符串
- 《剑指offer》刷题笔记(知识迁移能力):左旋转字符串
- 《剑指offer》-左旋转字符串
- 剑指Offer----面试题42(2):左旋转字符串
- 剑指offer(40)-左旋转字符串
- 剑指offer:左旋转字符串
- 剑指offer-左旋转字符串
- 《剑指offer》:[42-1]左旋转字符串
- 剑指offer——左旋转字符串
- 剑指Offer(Java版):反转单词顺序VS左旋转字符串
- 剑指offer--面试题42: 翻转单词顺序列 vs 左旋转字符串
- 《剑指offer》左旋转字符串