C++实现选择排序(selectionSort)

 更新时间:2020年04月26日 17:24:47   作者:ChanJose  
这篇文章主要为大家详细介绍了C++实现选择排序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C++实现选择排序的具体代码,供大家参考,具体内容如下

一、思路

每次取剩下没排序的数中的最小数,然后,填到对应位置。(可以使用a[0]位置作为暂存单元)

如下:

二、实现程序

#include <iostream>
using namespace std;
 
const int maxSize = 100;
 
template<class T>
void SelectSort(T arr[], int n); // 选择排序
 
int main(int argc, const char * argv[]) {
 int i, n, arr[maxSize];
 
 cout << "请输入要排序的数的个数:";
 cin >> n;
 cout << "请输入要排序的数:";
 for(i = 1; i <= n; i++) // arr[0]不存放值,用来做暂存单元
 cin >> arr[i];
 cout << "排序前:" << endl;
 for(i = 1; i <= n; i++)
 cout << arr[i] << " ";
 cout << endl;
 SelectSort(arr, n);
 cout << "排序后:" << endl;
 for(i = 1; i <= n; i++)
 cout << arr[i] << " ";
 cout << endl;
 return 0;
}
 
// 直接选择排序
template <class T>
void SelectSort(T arr[], int n) {
 int i, j, pos;
 
 for(i = 1; i < n; i++) { // 共作n-1趟选择排序
 pos = i; // 保存最小数的位置
 for(j = i; j <= n; j++) { // 找比arr[i]更小的值
  if(arr[j] < arr[pos]) {
  pos = j; // 指向更小的数的位置
  }
 }
 if(pos != i) { // 找到了更小的值,就交换位置
  arr[0] = arr[i]; // arr[0]作为暂存单元
  arr[i] = arr[pos];
  arr[pos] = arr[0];
 }
 } // for
} // SelectSort

测试数据:

7

20 12 50 70 2 8 40

测试结果:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C 语言基础教程(我的C之旅开始了)[十]

    C 语言基础教程(我的C之旅开始了)[十]

    C 语言基础教程(我的C之旅开始了)[十]...
    2007-02-02
  • C++实现模板中的非类型参数的方法

    C++实现模板中的非类型参数的方法

    这篇文章主要介绍了C++实现模板中的非类型参数的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • C++日期类计算器的模拟实现举例详解

    C++日期类计算器的模拟实现举例详解

    两个日期之间相隔天数的计算网上有许多的软件,这里主要介绍如何使用C/C++语言来完成这样的功能,下面这篇文章主要给大家介绍了关于C++日期类计算器的模拟实现,需要的朋友可以参考下
    2023-04-04
  • C语言高效实现向量循环移位

    C语言高效实现向量循环移位

    这篇文章主要为大家详细介绍了C语言高效实现向量循环移位,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-03-03
  • 总结C语言中const关键字的使用

    总结C语言中const关键字的使用

    一起虽然学过c语言,但是并没有写过太多的代码,最近想要拾起c语言,就写了一些代码,但是对const关键字比较陌生,这里总结一下,方法自己和大家有需要的时候参考借鉴,下面跟着小编一起学习学习吧。
    2016-11-11
  • C/C++ 中const关键字的用法小结

    C/C++ 中const关键字的用法小结

    C++中的const关键字的用法非常灵活,而使用const将大大改善程序的健壮性。这篇文章主要介绍了C/C++ 中const关键字的用法,需要的朋友可以参考下
    2020-02-02
  • C语言键盘控制走迷宫小游戏

    C语言键盘控制走迷宫小游戏

    这篇文章主要为大家详细介绍了C语言键盘控制走迷宫小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • C++ OpenCV实战之图像透视矫正

    C++ OpenCV实战之图像透视矫正

    这篇文章主要介绍了通过C++ OpenCV实现图像的透视矫正,文中的示例代码讲解详细,对我们的学习或工作有一定的参考价值,感兴趣的可以了解一下
    2022-01-01
  • Qt实现网易云音乐进度条效果

    Qt实现网易云音乐进度条效果

    这篇文章主要为大家详细介绍了Qt实现网易云音乐进度条效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-08-08
  • 教你Visual Studio 2022如何新建一个C语言工程(图文详解)

    教你Visual Studio 2022如何新建一个C语言工程(图文详解)

    这篇文章主要介绍了Visual Studio 2022如何新建一个C语言工程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-09-09

最新评论