7-41 实验7_6_数组交换 (100 分)

设有整数数组A和B,它们长度均为n。A数组中的元素为任意整数,不超过int型数据范围。B数组中元素的值互不相同,且取值介于0至n-1之间。现要求按数组B的内容调整A中数据的次序,比如当B[0]=9时,则要求将A[0]的内容与A[9]互换。

输入格式:

首先输入一个整数n(0<n<=10),代表数组A、B元素的个数。然后输入n个整数代表数组A中的元素。最后输入 n个整数代表数组B中的元素,注意B中元素的要求。测试用例保证所有整数可以用int存储。

输出格式:

调整后A数组的内容,数与数之间用空格分开,注意第n个数后没有空格而是换行符。

输入样例:

10
5 10 3 9 4 12 8 7 11 2
1 3 6 9 2 7 0 8 5 4

输出样例:

3 9 4 2 5 12 10 11 7 8
#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);

    int A[n],B[n];
    int i,hold=0;

    for(i=0;i<=n-1;i++)
        scanf("%d",&A[i]);
    for(i=0;i<=n-1;i++)
    {
        scanf("%d",&B[i]);
        hold=A[B[i]];
        A[B[i]]=A[i];
        A[i]=hold;
    }
    for(i=0;i<=n-1;i++)
        if(i!=n-1)
            printf("%d ",A[i]);
        else
            printf("%d\n",A[i]);

    return 0;
}
上一篇:XDOJ 41-PM2.5


下一篇:C# winform (上升沿触发以及值改变产生瞬间触发一次)类统一封装构造函数