面试题:移动数组的元素

原创 2018年04月16日 16:27:11

加qq 1126137994 一起学习更多技术!!!

描述
试设计一个算法,将数组a中的元素a[0]至a[n-1]循环右移k位,并要求只用一个元素大小的附加存储,元素移动或交换次数为O(n)。

输入
先输入一个大于1且小于100的正整数n,再输入n个整数存到数组a中,最后输入一个小于n正整数k,

输出
循环移动k位后输出。

输入样例
5
2 6 15 39 5
3

输出样例
15 39 5 2 6

如果做题的功底不好,一开始只会想到额外申请一个大小为k的数组,将原数组需要右移的k后面k个元素放到申请的数组里,然后将前面剩余的元素右移k位,再把额外数组的k个元素放到原数组的前k位。
这样做,浪费的空间,当需要移动的个数比较大,就会浪费更大的空间,所以面试官肯定不会满意!!!

其他算法:
应该这样做:
1、将整个数组置换(a[i]<=>a[n-1-i])

2、将前k个数置换

3、将后n-k个数置换

下面是我自己写的程序:

#include<iostream>

using namespace std;

//交换a[i]与a[n-i-1]
void swapa(int* a,int n)
{
    for (int i = 0; i <= (n - 1) / 2; i++)
    {
        int temp;
        temp = a[i];
        a[i] = a[n-1-i];
        a[n - 1 - i] = temp;
    }

}

//数组的前k个数置换a[i]与a[k-1-i]
void swappre_k(int* a,int k)
{
    for (int i = 0; i <= (k - 1) / 2; i++)
    {
        int temp;
        temp = a[i];
        a[i] = a[k-1-i];
        a[k - 1 - i] = temp;
    }
}

void swapafter_k(int* a,int n, int k)
{
    int m = n - 1;
    for (int i = k; i <= ( n- 1 + k) / 2; i++)
    {
        int temp;
        //int m = n - 1;
        temp = a[i];
        a[i] = a[m];
        a[m] = temp;
        m--;
    }
}

int main()
{
    int a[100], n, k;
    scanf_s("%d",&n);
    for (int i = 0; i < n; i++)
    {
        scanf_s("%d",&a[i]);
    }
    scanf_s("%d",&k);
    cout << " 移动前数组元素: " << endl;
    for (int i = 0; i < n; i++)
    {
        cout << a[i] << ' ';
    }
    cout << endl;
    //首先是整个数组置换
    int* p = a;
    swapa(p,n);
    //然后是前k个数置换
    swappre_k(p,k);
    //最后是后n-k个数置换
    swapafter_k(p,n,k);
    cout << " 移动后数组元素: " << endl;
    for (int i = 0; i < n; i++)
    {
        cout << a[i] << ' ';
    }

    getchar();
    return 0;
}

阅读性不是很好!再看看一个简单的写法:

#include<iostream>

using namespace std;

void swap(int* a, int* b)
{
    int temp = *a;
    *a = *b;
    *b = temp;
}

void swap_reserve(int* a, int* b)
{
    while (a < b)
        swap(a++,b--);
}

void shift(int* a, int n, int k)
{
    swap_reserve(a,a+n-1);
    swap_reserve(a,a+k-1);
    swap_reserve(a + k, a + n - 1);
}

//数组的前k个数置换a[i]与a[k-1-i]


int main()
{
    int a[100], n, k;
    scanf_s("%d",&n);
    for (int i = 0; i < n; i++)
    {
        scanf_s("%d",&a[i]);
    }
    scanf_s("%d",&k);
    cout << " 移动前数组元素: " << endl;
    for (int i = 0; i < n; i++)
    {
        cout << a[i] << ' ';
    }
    cout << endl;

    int* p = a;
    shift(p,n,k);
    cout << " 移动后数组元素: " << endl;
    for (int i = 0; i < n; i++)
    {
        cout << a[i] << ' ';
    }

    getchar();
    return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载,转载请加博主qq:1126137994或者微信:liu1126137994,送原稿。否则将追究法律责任。 https://blog.csdn.net/qq_37375427/article/details/79961962

数组

-
  • 1970年01月01日 08:00

将数组中指定数量的元素移动数组后面

static void Main() { int[] array = { 1, 2, 3, 4, 5, 6, 7 }; MoveNumb...
  • ws_hgo
  • ws_hgo
  • 2011-11-04 11:10:15
  • 1648

数组元素移动

描述 试设计一个算法,将数组a中的元素a[0]至a[n-1]循环右移k位,并要求只用一个元素大小的附加存储,元素移动或交换次数为O(n)。   输入 先输入一个大于1且小于100的正整数n,再...
  • axiqia
  • axiqia
  • 2016-03-25 19:08:44
  • 1503

iOS开发,一个数组,里面的元素依次的向后移动,移出的元素依次补到第一个位置

iOS开发,一个数组,里面的元素依次的向后移动,移出的元素依次补到第一个位置(数组元素为1,2,3,4,5; 向右移动两位后变为4,5,1,2,3)...
  • sinat_25027073
  • sinat_25027073
  • 2015-04-28 21:14:08
  • 517

js实现数组元素上下移动

交换数组可以实现元素上下移动了,这个效果我们在表格或以前排序算法中都会用到,下面来看一个JavaScript下实现交换数组元素上下移动例子 在写项目的时候,要实现一个数组记录上下移动的示...
  • helloxiaoliang
  • helloxiaoliang
  • 2016-12-14 13:18:27
  • 3862

将数组元素循环右移k个位置(Java实现)

用四种方法实现了将数组元素循环右移k个位置,相关的解释作为注释放在代码里面了。 package movearrayelement; import java.util.BitSet; public...
  • l294265421
  • l294265421
  • 2015-08-26 21:17:55
  • 5379

java 数组元素位移的简单方法(ArrayList add方法源码)

ArrayList中有个方法是public void add(int index, E object) 这个方法是在第index位置上插入元素。 按照常规做法,肯定是,将数组中index(包括in...
  • gacmy
  • gacmy
  • 2016-07-05 16:16:07
  • 1662

将数据中的元素都向前移动一个位置,最后一个元素的值是原来第一个元素的值,然后输出这个数组。

/* 定义一个int 型的一组数据,包含10个元素,分别赋值为1~10,然后将数据中的元素都向前移动一个位置,最后一个元素的值是原来第一个元素的值,然后输出这个数组。  */ int mai...
  • u012189584
  • u012189584
  • 2014-09-07 11:39:25
  • 2725

数组的循环移动

数组的循环移动是考查的算法中比较常见的,有循环左移,循环右移之类的。当然,不会直接就考查移动的算法,还会有一定的时间复杂度,空间复杂度的要求之类的,这才是算法要求的,所以这两天刚好看到类似的题目,就记...
  • LilyNothing
  • LilyNothing
  • 2017-03-21 18:08:08
  • 574

C语言实现一个数组每个元素依次向右移动k位(后面的往前面补,不开辟新空间)

实现一个数组每个元素依次向右移动k位(后面的往前面补,不开辟新空间)
  • Mr_tian2016
  • Mr_tian2016
  • 2016-08-17 00:01:23
  • 2022
收藏助手
不良信息举报
您举报文章:面试题:移动数组的元素
举报原因:
原因补充:

(最多只允许输入30个字)