原创 将数组元素分成两部分,再整体交换位置

2011-6-26 21:17 2914 6 6 分类: 软件与OS

昨日去某公司笔试,碰到一个题如下:

    对于一个数组,已知其长度为n,和一小于n的正整数p,将该数组的前p个元素和后面的元素交换一下位置,例如a[15]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15},若p=6,则输出为{7,8,9,10,11,12,13,14,15,1,2,3,4,5,6},
要求占用尽可能少的空间。

    思路:其实方法很简单,将每一个元素都向前移动一位,移动P次即可,不要陷入怎么分段拷贝的思路中。

1 #include<iostream.h>
2
3  void move(int *s,int m,int n);
4
5 void main()
6 {
7 int p;
8 int arr[15]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15};
9 cout<<"the orignal array data is:"<<endl;
10 for(int i=0;i<15;i++)
11 cout<<arr<<" ";
12 cout<<endl;
13
14 cout<<"please input a integer:";
15 cin>>p;
16
17 move(arr,p,sizeof(arr)/sizeof(arr[0]));
18
19 cout<<"the output arry is:"<<endl;
20 for(i=0;i<15;i++)
21 cout<<arr<<" ";
22 cout<<endl;
23 }
24
25 void move(int *s,int m,int n)
26 {
27 for(int i=0;i<m;i++)
28 {
29 int temp=s[0];
30 for(int j=0;j<n-1;j++)
31 s[j]=s[j+1];
32 s[n-1]=temp;
33
34 }
35
36 }
PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
6
关闭 站长推荐上一条 /3 下一条