《剑指Offer》面试题:对字符串进行循环左移
2015-09-12 21:37
459 查看
题目
/*题目描述:
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。
对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。
输入:
多组测试数据,每个测试数据包含一个字符序列S和非负整数K。其中S的长度不超过1000。
输出:
对应每个测试案例,输出新序列。
样例输入:
UDBOJ 4
abba 1
样例输出:
JUDBO
bbaa
如果我们直接在输出时表现为将输入的字符串循环移位了(原字符串并没有进行循环移位)
则可以这样做,如下/* 需要考虑的测试用例 1)正常输入(n<len):str="abcdefghijklmn" n=5 2)正常输入(n>len):str="abcdefghijklmn" n=5 3)特殊的输入 */ #include<stdio.h> #include<stdlib.h> #include<string.h> void ROLString(char *str,int n){ if(str==NULL||n<0){//根据条件n不能小于0,其实在实际情况的循环左移中,n是可以小于0 的 return ; } int len=strlen(str); if(len<=0){ return; } if(len==1){ puts(str); } n=n%len;//循环移动n次与移动n%len相同,故通过求余 for(int i=0;i<len;i++){ putchar(str[(i+n)%len]); } } int main(void){ char str[1000]; int n; while(scanf("%s,%d",str,n)){ ROLString(str,n); } return 0; }
如果我们是想要在原字符串中完成翻转后再输出
则可以这样做思路
/*
思路:三次翻转字符串即可完成对字符串的循环移位
例如: str=”abcdefgh” k=3
第一次翻转:str=”cbadefgh” 即将str的前k个字符进行翻转
第二次翻转:str=”cbahgfed” 即将str从k+1之后的字符进行翻转
第三次翻转:str=”defghabc” 最后将str整体进行翻转即完成了字符的循环移位
*/
#include<stdio.h> #include<stdlib.h> #include<string.h> void swap(char *a,char *b){ int temp=*a; *a=*b; *b=temp; } void reverseString(char *str,int l,int r){ if(str==NULL||l>=r||l<0||r<0){ return; } while(l<r){ swap(&str[l],&str[r]); l++; r--; } } void ROLString(char *str,int n){ if(str==NULL||n<0){//根据条件n不能小于0,其实在实际情况的循环左移中,n是可以小于0 的 return ; } int len=strlen(str); if(len<=1){ return; } n=n%len;//循环移动n次与移动n%len相同,故通过求余 if(n==0){ return; } reverseString(str,0,n-1); reverseString(str,n,len-1); reverseString(str,0,len-1); } int main(void){ char str[1000]; int n; while(scanf("%s %d",str,&n)){ ROLString(str,n); puts(str); } return 0; }
相关文章推荐
- 程序员必须知道的10大基础实用算法及其讲解
- 南京大学行业求职研究报告——投资银行篇
- 南京大学行业求职研究报告——投资银行篇
- 面试题6:重建二叉树
- 《剑指Offer》面试题:员工的年龄进行排序
- 我决定开始写技术博客了
- Java面试问题集锦02-Java语言开发环境
- 《剑指Offer》面试题:旋转数组的最小数字
- java面试问题集锦01-Java程序设计概述
- 你想成为优秀的Java程序员吗?
- 黑马程序员——IO流(上)
- 黑马程序员—Java基础—字符、随机数、包、for循环
- 黑马程序员 Java基础01__从HelloWorld到面向对象
- 面试题18:树的子结构
- 面试题之总结-大数运算
- 一个fork的面试题
- java 7K交通灯管理系统面试题
- 数据仓库面试资料(基本概念)
- leetcode面试准备:Implement Trie (Prefix Tree)
- 前端开发面试题 (题目列表页)