当前位置: 首页 > wzjs >正文

网站建设栏目设置表格精准客户截流软件

网站建设栏目设置表格,精准客户截流软件,网站如何清除百度收录,一级做爰A视频免费网站目录 1 选择排序 2 排序原理 3 排序步骤 4 代码示例 4-1 C#代码示例 4-2 C代码示例 1 选择排序 选择排序(Selection Sort)是一种简单直观的排序算法,它的基本思想是每一轮从待排序的数据元素中选出最小(或最大&#xff09…

目录

 1  选择排序

 2  排序原理

 3  排序步骤

 4  代码示例

 4-1  C#代码示例

 4-2  C++代码示例


 1  选择排序

选择排序(Selection Sort)是一种简单直观的排序算法,它的基本思想是每一轮从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,直到全部待排序的数据元素排完。

 2  排序原理

选择排序的核心原理是通过不断地选择最小(或最大)元素并将其放置到合适的位置,逐步构建有序序列。具体来说,它会将数组分为已排序部分和未排序部分,初始时已排序部分为空,未排序部分为整个数组。每一轮排序会从未排序部分中找出最小(或最大)的元素,然后将其与未排序部分的第一个元素交换位置,这样就使得已排序部分的长度增加 1,未排序部分的长度减少 1,重复这个过程直到未排序部分为空。

 3  排序步骤

下面以升序排序为例说明选择排序的步骤:

  1. 初始状态:给定一个包含 n 个元素的数组 arr,初始时整个数组都是未排序部分。
  2. 第一轮选择
    • 从数组的第一个元素开始,遍历整个数组,找出最小的元素。
    • 记录最小元素的索引。
    • 将最小元素与数组的第一个元素交换位置。此时,数组的第一个元素已经排好序,已排序部分包含 1 个元素,未排序部分包含 n - 1 个元素。
  3. 第二轮选择
    • 从数组的第二个元素开始,遍历剩余的未排序部分,找出最小的元素。
    • 记录最小元素的索引。
    • 将最小元素与数组的第二个元素交换位置。此时,数组的前两个元素已经排好序,已排序部分包含 2 个元素,未排序部分包含 n - 2 个元素。
  4. 重复选择过程:重复上述步骤,直到未排序部分只剩下一个元素。此时,整个数组就已经排好序。

 4  代码示例

 4-1  C#代码示例
using System;namespace ConsoleApplication1
{internal class Program{private static void SelectionSort(int[] arr){if (arr == null || arr.Length < 2) return;for (int i = 0; i < arr.Length - 1; i++){int minIndex = i;for (int j = i + 1; j < arr.Length; j++)minIndex = arr[j] < arr[minIndex] ? j : minIndex;Swap(arr,i,minIndex);}}private static void Swap(int[] arr, int i, int j){if (i!= j)      {arr[i] ^= arr[j];arr[j] = arr[i] ^ arr[j];arr[i] ^= arr[j];}}public static void Main(string[] args){int[] arr = { 2, 5, 7, 9, 3, 1, 4, 6, 8 };SelectionSort(arr);foreach (var value in arr)Console.WriteLine(value);}}
}

运行结果:

 4-2  C++代码示例
#include <iostream>
#include <vector>// 交换向量中两个位置元素的函数
void Swap(std::vector<int>& arr, int i, int j) {if (i != j) {arr[i] ^= arr[j];arr[j] = arr[i] ^ arr[j];arr[i] ^= arr[j];}
}// 选择排序函数
std::vector<int> SelectionSort(std::vector<int> arr) {if (arr.size() < 2) {return arr;}for (size_t i = 0; i < arr.size() - 1; ++i) {size_t minIndex = i;for (size_t j = i + 1; j < arr.size(); ++j) {if (arr[j] < arr[minIndex]) {minIndex = j;}}Swap(arr, static_cast<int>(i), static_cast<int>(minIndex));}return arr;
}int main() {std::vector<int> arr = { 2, 5, 7, 9, 3, 1, 4, 6, 8 };arr = SelectionSort(arr);for (int value : arr) {std::cout << value << std::endl;}return 0;
}

运行结果:

http://www.dtcms.com/wzjs/494355.html

相关文章:

  • 邯郸市人力资源和社会保障局网站推广优化教程
  • 用vs做网站在安装时要勾选百度极速版下载
  • 做一个网站开发项目有哪些阶段seo排名系统源码
  • 小男孩做愛网站南宁seo规则
  • 新乡市做网站的公司阿里大数据平台
  • 做网站前端需要编程基础吗google官网
  • 校园门户网站建设方案武汉百度关键词推广
  • 深圳龙华区简介北京网站优化方法
  • 网站做滚动图片百度推广账户优化
  • 英文商务网站制作b2b外贸平台
  • 网站建设了解在线crm网站建站
  • 衡水 网站建设网站排名大全
  • 网站seo诊断分析报告线下推广有哪几种渠道
  • 北京百度推广代运营seo主要是指优化
  • 电子购物网站建设视频什么平台可以推销自己的产品
  • 嘉兴做网站的站长统计app最新版本2023
  • 周到的宁波网站建设电脑培训学校
  • 建网站公安局不备案重庆森林百度云
  • 委托别人做网站 域名所有权网络推广的平台
  • php与H5做网站茶叶网络营销策划方案
  • 一个网站的制作流程长春seo整站优化
  • 网站建设文献综述模板网站seo诊断工具
  • 手机做ppt苹果手机下载网站一份完整的营销策划方案
  • 找钢网网站建设百度视频seo
  • 鄂州市城乡建设委员会网站职业技能培训网上平台
  • 美妆购物网站开发的总结厦门seo搜索排名
  • 百度收录好的网站排名今日热点新闻视频
  • 5118网站怎么做的站长工具国色天香
  • 长春火车站到吉大二院网络营销策划内容
  • 佛山网站制作咨询北京seo百度推广