首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将数组与其他数组进行比较后交换数组元素的最有效方法

将数组与其他数组进行比较后交换数组元素的最有效方法
EN

Stack Overflow用户
提问于 2017-07-23 17:39:54
回答 1查看 107关注 0票数 0

假设我们有两个数组:数组a1和数组a2。

“a1”和“a2”在某种程度上是相似的,它们都有相同的大小和相同的元素,但元素的出现顺序不同。

比较两个数组并找出使数组'a1‘与'a2’的顺序相同所需的最小交换次数的最有效方法是什么?

例如:

代码语言:javascript
复制
int a1[5] = { 1, 2, 3, 4, 5};
int a2[5] = { 2, 3, 1, 5, 4};

因此,所需的最小交换数量为:3

在步骤中:

交换1: a1 <-> a11

交换2: a11 <-> a12

交换3: a13 <-> a14

因此,最终a1将包含{ 2,3,1,5,4}

EN

回答 1

Stack Overflow用户

发布于 2017-07-23 18:37:09

代码语言:javascript
复制
int numofchanges = 0;
for(int i = 0; i < sizeOfArrays; i++)
{
    int arr3[] = arr1;
    for(int n = 0; n < sizeOfArrays; n++)
    {
         arr3[i] = arr1[n];
         if(arr3[i] == arr2[i])
         {
             int tmp = arr1[i];
             arr1[i] = arr1[n];
             arr1[n] = tmp;
             numofchanges++;
         }
    }
}

警告这不会运行类似于伪代码

变量numofchanges将保存更改的数量,现在arr1将为arr2

我希望这对你有帮助。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45263638

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档