> 백엔드 개발 > C++ > 본문

选择排序的C程序

PHPz
풀어 주다: 2023-08-28 13:13:05
앞으로
677명이 탐색했습니다.

选择排序的C程序

选择排序是一种攻击性算法,它的工作原理是从数组中找到最小的数字,然后将其放在第一个位置。下一个要遍历的数组将从最小数字所在位置的下一个索引开始。

让我们举个例子来更清楚地说明这个概念。

我们有一个数组 {6, 3, 8, 12, 9} 在这个数组中最小的元素是 3。所以我们将 3 放在第一个位置,之后数组将看起来像 {3, 6, 8, 12, 9} 。现在我们将再次找到最小的数字,但这次我们不会在搜索中考虑 3,因为它在它的位置。找到下一个最小元素 6,在第二个位置创建一个包含 6 的数组,然后再次在数组中搜索,直到数组排序完毕。

选择排序算法的工作原理 -

选择排序算法遵循以下步骤

让我们采用一个数组 {20, 12 , 23, 55 ,21}

  • 将数组的第一个元素设置为最小值。

    最小值= 20

  • 将最小值与下一个元素进行比较,如果它小于最小值分配该元素为最小值。这样做直到数组末尾。

    与 12 : 20 > 12 比较,最小值 = 12

    与 23 : 12 与 55 比较:12

    与 21 比较:12

  • 将最小值放在数组的第一个位置(索引 0)。

    Array = {12, 20 ,23, 55, 21}

  • 对于下一次迭代,开始从第一个未排序元素开始排序。

    Array = {12, 20 ,23, 55, 21}

    从 20 开始搜索,下一个放置最小值的元素。

    迭代 2:

    最小值 = 20

    与 23 相比:20

    与 55 相比:20

    与 21 相比:20

    最小值不变,

    数组 = {12, 20 ,23, 55, 21}

    迭代 3:

    最小值 = 23。

    与 55 相比:23

    与 21 相比: 23 > 21 ,最小值 = 21

    最小值移至索引 = 2

    Array = {12, 20, 21, 55, 23}

    迭代 4:

    最小值 = 55

    与 23 相比:23

    最小值移至索引 3 数组 = { 12 , 20 , 21 , 23 , 55 }

示例

#include 
int main() {
   int arr[10]={6,12,0,18,11,99,55,45,34,2};
   int n=10;
   int i, j, position, swap;
   for (i = 0; i < (n - 1); i++) {
      position = i;
      for (j = i + 1; j < n; j++) {
         if (arr[position] > arr[j])
            position = j;
      }
      if (position != i) {
         swap = arr[i];
         arr[i] = arr[position];
         arr[position] = swap;
      }
   }
   for (i = 0; i < n; i++)
      printf("%d\t", arr[i]);
   return 0;
}
로그인 후 복사

输出

0 2 6 11 12 18 34 45 55 99
로그인 후 복사

위 내용은 选择排序的C程序의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!