O(n)时间O(1)辅助空间,循环移位
这一道,google的笔试题,网易也用过,学校的数据结构题目系统也有,之前我都是卡着机器出的
现在整理一下
一 3次翻转做法
/*about 循环移位
实例:abcdefgh 向左循环移位3位
结果 defghabc
1.abc做翻转
cba defgh
2 defgh做翻转 cba
hgfed
3.第二结果全部在做翻转 成为
defghabc */
template<class T>
void reverse(T a[],int i,int j)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
while(i < j)
data:image/s3,"s3://crabby-images/788e5/788e5df7a2b54adca27f5032aa9631ef1512545d" alt=""
{
swap(a[i],a[j]);
++i;
--j;
}
}
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
data:image/s3,"s3://crabby-images/54783/547830fede928f19a3ce63b212a632c66666c748" alt=""
template<class T>
void exch1(T a[],int n,int k)
data:image/s3,"s3://crabby-images/d8aef/d8aef1ca72194cc1f263ac1b681faa2e7d2ee4af" alt=""
data:image/s3,"s3://crabby-images/c9e2b/c9e2bc817d66f0a3894ba04ea7703b8e0b7b6162" alt=""
{
reverse(a,0,k-1);
reverse(a,k,n-1);
reverse(a,0,n-1);
}
reverse(a,0,k-1); // k/2
reverse(a,k,n-1); // (n-k)/2
reverse(a,0,n-1); // n/2
为 k/2+(n-k)/2+k/2=n/2 + n/2 = n
二 ...
posted on 2009-11-26 12:40
爬 阅读(1261)
评论(3) 编辑 收藏 引用 所属分类:
algorithm