对字符序列循环向左(右)移动的技巧
来源:互联网 发布:淘宝在线客服人工在哪 编辑:程序博客网 时间:2024/06/05 08:39
给出一个字符序列S,求对S向左(右)循环移动i后的字符序列。
比如:S = abcdefg, i = 3, 则操作完成后S = defgabc (向右同理哦)
技巧:假如S = abcdefg, i = 3, 那么可以进行如下操作:
1) 对S的前i个字符进行翻转, 对于上例,则可以得到 abc => cba
2) 对S中i以后的字符进行翻转,那么可以得到 defg => gfed
3) 经过以上两步后,S = cbagfed, 最后对S整体翻转,可到 cbagfed => defgabc
#include <stdio.h>#include <string.h>#define MAX_N 505char str[MAX_N];int i;void toRev(char* str, int s, int e) {char* left = str + s;char* right = str + e;char c;while (left < right) {c = *right;*right-- = *left;*left++ = c;}}int main() {int len;while (scanf("%s%d", str, &i) != EOF) {len = strlen(str);i = i % len;// 三次翻转toRev(str, 0, i - 1);toRev(str, i, len - 1);toRev(str, 0, len - 1);printf("%s\n", str);}return 0;}向右循环移动的方法也类似。
- 对字符序列循环向左(右)移动的技巧
- 图片由右向左循环滚动
- 从右向左的progressBar
- bitmap画向左---右的按钮
- 将一篇文章的按单词倒序,将一个字符串向左循环移动
- 将一个长度为n的字符串向左循环移动m位
- 完美算法 --将一个具有n个元素的数组向左循环移动i个位置
- 【算法题】字符串向左或向右循环移动
- 一个有n个整数的递增有序数组。对它进行向左或向右循环移动若干次后,要求给出一个代码实现,尽可能快地从这个数组中寻找指定值所在的位置
- 向左走向右走
- 向左走向右走?
- 向左走向右走
- 自右向左滚动
- MATLAB 循环移位序列,二进制的按位循环右移/左移
- unity 向左向右移动的实现
- 字符串循环右移动n位
- 字符串循环右移动K位
- 将一个具有n个元素的数组向左循环移动i个位置,使用O(n)复杂度
- 31讲 PHP开发环境的搭建和使用① appserv套件安装
- hdu 4768 Flyer 二分(2013 ACM/ICPC Asia Regional Changchun Online 1010)
- 32讲 PHP开发环境的搭建和使用② 自定义安装
- 交换变量的方法
- ZigBee与蓝牙
- 对字符序列循环向左(右)移动的技巧
- 巧用 iTunes 转换 caf 格式铃声
- 哈哈
- 程序员面试问题
- 判断单链表中是否存在环及查找环的入口点
- 50件开心事,你经历了多少?
- linux-arm中断系统之GIC
- 33讲 PHP开发环境的搭建和使用③ 安装并配置discuz论坛
- 35讲 PHP运行过程时序图 PHP书写规范