为啥这个选择排序代码在 Cpp 中,没有给出所需的输出

Posted

技术标签:

【中文标题】为啥这个选择排序代码在 Cpp 中,没有给出所需的输出【英文标题】:Why this Selection sort code in Cpp, not giving required Output为什么这个选择排序代码在 Cpp 中,没有给出所需的输出 【发布时间】:2014-10-29 20:07:58 【问题描述】:
#include<iostream>

using namespace std;
int min_arr(int arr[],int size);
void swap(int *,int *);
int main()

    int arr[10]=31,2,55,3,77,12,89,98,43,34,loc;
    int* arr1;
    arr1 = &arr[0];
    for(int i=0;i<10;i++)
    
        for( int j=i;j<9;j++)
        
            loc = min_arr(arr1,(10-i));
            swap(&arr[loc],&arr[i]);
            arr1++;
        
       

    for(int i =0; i<10;i++)
        cout<<arr[i]<<endl;

    return 0;


int min_arr(int arr[],int size)

    int k=0;
    int temp=arr[0];
    for(int i=1;i<size;i++)
    
        if(arr[i]<temp)
        
            temp=arr[i];
            k=i;
           
    

    return k;


void swap(int *a, int *b)

   int temp;
   temp=*a;
   *a=*b;
   *b=temp;
  

为什么 Cpp 中的选择排序代码没有给出所需的输出?请找出漏洞!在进行过程中,我使用了两个函数来查找子数组的最小值。当我找到最小值时,我返回它的索引并交换子数组的第一个位置和最小值元素!

【问题讨论】:

【参考方案1】:

重新排列代码并添加一些调试行后,很容易找出问题所在:

首先,第二个循环(j循环)完全没有意义 其次,loc 变量不是基于 0,而是基于 i(当您搜索 arr1,它由循环递增),所以 arr[loc] 应该是 arr[loc+i]

更正、巧妙的缩进(这对于使游览代码易于阅读很重要)代码:

#include<iostream>

#define ARRAY_SIZE 10
using namespace std;
int min_arr(int arr[],int size);
void swap(int *,int *);
int main()

    int arr[ARRAY_SIZE]=31,2,55,3,77,12,89,98,43,34,loc;
    int* arr1;
    arr1 = &arr[0];
    for( int i = 0; i < ARRAY_SIZE; i++ )
    
        //for( int j = i; j<ARRAY_SIZE-1; j++ )
        
            loc = min_arr(arr1,(ARRAY_SIZE-i));
            // for debug:
            //std::cout << "min found at " << loc << std::endl;
            swap(&arr[loc+i],&arr[i]);

            // for debug:
            //for( int i =0; i<ARRAY_SIZE; i++ )
            //  cout << arr[i] << " ";
            //cout << std::endl;

            arr1++;
        
       

    for( int i =0; i<ARRAY_SIZE; i++ )
        cout<<arr[i]<<endl;

    return 0;


int min_arr( int arr[], int size )

    int k=0;
    int temp=arr[0];
    for( int i=1; i<size; i++ )
    
        if( arr[i] < temp )
        
            temp=arr[i];
            k=i;
           
    
    return k;


void swap(int *a, int *b)

    int temp;
    temp=*a;
    *a=*b;
    *b=temp;
  

它会输出:

2
3
12
31
34
43
55
77
89
98

【讨论】:

我不明白你所说的关于 loc 的内容。为什么它是 loc+i ? loc 是 arr1 中最小值的位置。但是,由于 arr1 通过循环递增 arr1[loc] 实际上是 arr[loc+i] (因为 arr1 实际上是 arr+i)。【参考方案2】:

在您的版本中,您只需使用超出为数组映射的区域的指针。

首先,调用函数min_arr。它需要数组,而不是指针:

loc=min_arr(arr,(10-i));

第二,函数本身。你总是从数组的开头开始,这就是为什么已经排序的元素会被重新使用。

int min_arr(int arr[],int size)

int k=10-size;
int temp=arr[k];
for(int i=k+1;i<10;i++)

    if(arr[i]<temp)
    
        temp=arr[i];
        k=i;
    
    

   return k;

【讨论】:

我没明白这一点。首先:- 函数 min_arr() 已经采用数组参数。其次,我的函数从头开始,因为我正在解析数组 'arr1' 而不是 'arr' !我猜你所说的将消除对 'arr1' 的需要? 是的,arr1 中不再需要了。我假设,您希望该函数与子数组一起使用,将指向相应元素的指针传递给它,但有几个问题:1) arr1 超出了为数组映射的区域,因为它是在内部循环 2 中引入的)您尝试使用函数 min_arr 中的子数组索引,但是然后您将 &arr[loc] (因此 loc 现在是原始数组中的索引)转移到交换这就是为什么我建议传递给 min_arr 原始数组和元素的索引,你想从那里开始寻找一分钟【参考方案3】:
for(int i=0;i<10;i++)
  
    for( int j=i;j<9;j++)  //shouldn't this be j < 10 ?
......

【讨论】:

很抱歉投了反对票,但是您应该在提出任何答案之前测试您的代码...实际上,这个 j 循环是毫无意义的,您的提议不会使代码工作...

以上是关于为啥这个选择排序代码在 Cpp 中,没有给出所需的输出的主要内容,如果未能解决你的问题,请参考以下文章

为啥选择排序算法的这段代码没有给出输出?

使用 matplotlib 绘图没有给出所需的日期时间格式

在 Dev-C++ 中,为啥我导入了项目所需的文件却无法编译我的项目?

无法获取表单以验证所需的选择输入

为啥我的 ArrayList 没有打印出 Java 所需的输出?

为啥好多东西运行不了。出现“找不到所需的.dll文件?”