SDUT 3363 顺序表应用4-2:元素位置互换之逆置算法(数据改进)

顺序表应用4-2:元素位置互换之逆置算法(数据改进)

Time Limit: 80 ms Memory Limit: 600 KiB

Submit Statistic

Problem Description

一个长度为len(1<=len<=1000000)的顺序表,数据元素的类型为整型,将该表分成两半,前一半有m个元素,后一半有len-m个元素(1<=m<=len),设计一个时间复杂度为O(N)、空间复杂度为O(1)的算法,改变原来的顺序表,把顺序表中原来在前的m个元素放到表的后段,后len-m个元素放到表的前段。
注意:交换操作会有多次,每次交换都是在上次交换完成后的顺序表中进行。

Input

第一行输入整数len(1<=len<=1000000),表示顺序表元素的总数;

第二行输入len个整数,作为表里依次存放的数据元素;

第三行输入整数t(1<=t<=30),表示之后要完成t次交换,每次均是在上次交换完成后的顺序表基础上实现新的交换;

之后t行,每行输入一个整数m(1<=m<=len),代表本次交换要以上次交换完成后的顺序表为基础,实现前m个元素与后len-m个元素的交换;

Output

输出一共t行,每行依次输出本次交换完成后顺序表里所有元素。

Sample Input

10
1 2 3 4 5 6 7 8 9 -1
3
2
3
5

Sample Output

3 4 5 6 7 8 9 -1 1 2
6 7 8 9 -1 1 2 3 4 5
1 2 3 4 5 6 7 8 9 -1

Hint

Source

#include 
#include 
#define max 1000005
using namespace std;
int *data;
int m, len;

// 元素翻转   如 1 2 3 4 5   ---》   5 4 3 2 1
void reverse(int begin, int end, int m) {
    for (int i = 0; i < m; i++) {
        int temp = data[begin];
        data[begin++] = data[end];
        data[end--] = temp;
    }
}

int main() {
    int t;
    // 下面两种是在堆里申请内存  int data[1000000] 是在栈里申请
    // data = new int[max];
    data = (int *)malloc(max * sizeof(int));  // 不手动申请内存  会爆内存
    scanf("%d", &len);
    for (int i = 0; i < len; i++) {
        scanf("%d", &data[i]);
    }
    scanf("%d", &t);
    while (t--) {
        scanf("%d", &m);

        reverse(0, len - 1, len / 2);      // 变成 -1 9 8 7 6 5 4 3 2 1
        reverse(len - m, len - 1, m / 2);  // 变成 -1 9 8 7 6 5 4 3   1 2
        reverse(0, len - m - 1, (len - m) / 2);  // 变成 3 4 5 6 7 8 9 -1   1 2

        for (int i = 0; i < len; i++) {
            if (i == len - 1) {
                printf("%d\n", data[i]);
            } else {
                printf("%d ", data[i]);
            }
        }
    }

    return 0;
}

 

你可能感兴趣的:(数据结构-顺序表)