字符串反转及数组奇偶划分
2015-04-26 09:46
363 查看
//将字符串反转,型如:123 456 789 abc ,反转后的结果是 abc 789 456 123 /* #include <iostream> #include <string.h> using namespace std; void Exchange(char *&str) { char *p=str+strlen(str)-1; char *q=str; while(q<p) { char temp=*q; *q=*p; *p=temp; q++; p--; } } void Grial(char *str) { char *p = str; while(*p!='\0') { char *p_1=p; while(*p!=' ')p++; char *save=p+1; *p='\0'; Exchange(p_1); *p=' '; p=save; } Exchange(str); } int main() { char s[]="12345 1234 abc"; Grial(s); cout<<s<<endl; return 0; } //原理是将整个字符串中单个字符串(以空格分割)反转,形如abc 123,第一步操作之后是 cba 321, //第二步再将整个字符串整体反转,操作之后的结果是 123 abc ,就达到了反转字符串的效果,且不改变原来单个字符串的顺序. */ //百度笔试:给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数 //要求:空间复杂度o(1),时间复杂度o(m)。 /*#include <iostream> using namespace std; void Grial(int a[],int x) { int i=-1; int j=0; int temp; while(j<x) { while(j!=(x-1) && a[j]%2==0)j++; i++; temp = a[i]; a[i] = a[j]; a[j] = temp; j++;//每次将偶数放在i的位置,所以i的位置从-1开始,直到j=x时,i的左边全市奇数,i的右边全市偶数. } } int main() { int a[]={9,6,4,2,43,5,1,43,5,6}; Grial(a,10); for(int i=0;i<10;i++) { cout<<a[i]<<" "; } }*/
相关文章推荐
- 将一个字符串数组的元素的顺序进行反转
- 从面试开始_数组的反转&字符串转数字
- 划分字符串为字符串数组
- JAVA实现字符串反转,借助字符数组实现
- JAVA实现字符串反转,借助字符数组实现
- 去除字符串两端的空格&&将字符串反转&&将字符串转换为字符数组
- 一个JavaScript递归实现反转数组字符串的实例
- 一个JavaScript递归实现反转数组字符串的实例
- 黑马程序员之C#编程基础学习笔记:将一个字符串数组的元素的顺序进行反转。
- 数据结构之数组和字符串的反转java实现
- poj 1226 出现或反转后出现在每个字符串中的最长子串(后缀数组/kmp)
- POJ 1226后缀数组:求出现或反转后出现在每个字符串中的最长子串
- 关于字符串反转和数组反转的问题
- 将一个字符串数组的元素的顺序进行反转(C#)
- 中文字符串的反转,使用正则和数组实现
- 数组循环移位O(n) AND 按单词反转字符串
- 一些常用算法[数组全排列算法,单链表反转(递归实现),字符串反转,桶排序]
- 编程之美的2.17,数组循环移位 & 字符串逆转(反转) Hello world Welcome => Welcome world Hello
- 每天一个JavaScript实例-递归实现反转数组字符串
- 实现数组反转及字符串反转的方法