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

skech做网站交互流程宁波seo教程app推广

skech做网站交互流程,宁波seo教程app推广,wordpress 缩进 插件,柳州学校网站建设1、冒泡排序 冒泡排序是从下标 1 遍历到 n,每当遇到大于下一个的,就和上一个交换位置,这样最大的就移动到了 n 的位置,然后从头再从 1 遍历到 n-1,把第二大的移动到 n-1 的位置,依此类推,每次从…

1、冒泡排序

冒泡排序是从下标 1 遍历到 n,每当遇到大于下一个的,就和上一个交换位置,这样最大的就移动到了 n 的位置,然后从头再从 1 遍历到 n-1,把第二大的移动到 n-1 的位置,依此类推,每次从剩下的里面挑出最大的一个放在末尾。它的特点是每次遍历过程中都会不断的交换位置,即为冒泡排序,是一种稳定排序。

package com.fdw.algorithm.sort;import java.util.Arrays;/*** @program: RedisDemo* @description: 冒泡排序* @author: fudingwei* @create: 2024-05-30 13:58**/
public class BublingSort {public static void main(String[] args) {int[] array = new int[]{6,5,72,1,4,5,12,8,3,2,7};sort(array);System.out.println(Arrays.toString(array));}public static void sort(int[] array){for (int i = 0; i < array.length; i++) {boolean flag = true;//关键是j < array.length-i-1for (int j = 0; j < array.length-i-1; j++) {//冒泡排序的过程中不停的在交换if(array[j]>array[j+1]){swap(array,j,j+1);flag = false;}}//没有进行交换,说明已经有序if(flag){break;}}}public static void swap(int[] array,int left,int right){int temp = array[left];array[left] = array[right];array[right] = temp;}
}

2、选择排序

选择排序是是从下标 1 遍历到 n,找出最小数的下标,然后将最小数和下标 1 交换位置,然后再从下标 2 遍历到 n,找出第二小的数,将其和下标 2 交换位置,依此类推,每次从剩下的里面挑出最小的一个放在前面。它的特点是每次遍历过程中只会交换一次位置,即为选择排序,是一种不稳定排序。

package com.fdw.algorithm.sort;import java.util.Arrays;/*** @program: RedisDemo* @description: 选择排序* @author: fudingwei* @create: 2024-05-30 14:24**/
public class SelectSort {public static void main(String[] args) {int[] array = new int[]{6, 5, 72, 1, 4, 5, 12, 8, 3, 2, 7};sort(array);System.out.println(Arrays.toString(array));}public static void sort(int[] array) {for (int i = 0; i < array.length; i++) {int min = i;//每次选出最小的,存下标for (int j = i + 1; j < array.length; j++) {if (array[j] < array[min]) {min = j;}}//把最小的放第一位if (min != i) {swap(array, i, min);}}}public static void swap(int[] array, int left, int right) {int temp = array[left];array[left] = array[right];array[right] = temp;}
}

3、插入排序

插入排序是从第二位开始遍历,遍历时当这一位数小于前一位时,就会和前面的进行交换位置,如果交换完后该数仍然小于前一位,会继续交换,一直到该数不小于前一位为止,它的特点是每次遍历前都能保证前面的数据已经是递增的状态,将数据插入到已有顺序中它应该在的位置,即为插入排序,是一种稳定排序。

package com.fdw.algorithm.sort;import java.util.Arrays;/*** @program: RedisDemo* @description: 插入排序* @author: fudingwei* @create: 2024-05-30 11:54**/
public class InsertSort1 {public static void main(String[] args) {int[] data = {1,1,2,8,4,2,1,6,4,8,6,9,2,1};sort(data);System.out.println(Arrays.toString(data));}public static void sort(int[] array){for (int i = 1; i < array.length; i++) {//遍历i前的值 大于array[i]就后移,一边移动一边排序,保证了temp前的数据一定是递增的for (int j = i-1; j >=0; j--) {if(array[j]>array[j+1]){//交换swap(j+1,j,array);}else {break;}}}}public static void swap(int l,int r,int[] array){int temp = array[l];array[l] = array[r];array[r] = temp;}
}

 总结

三种排序算法都是使用了两个for循环来遍历,时间复杂度都是O(n的平方),选择排序是不稳定的,其他两种是稳定的,三种算法都涉及到位置的交换,选择排序交换的次数最少。

http://www.hkea.cn/news/283113/

相关文章:

  • 广州免费核酸检测点东莞seo项目优化方法
  • 学风建设网站版块设计个人网站
  • 网站底部连接怎么做福州seo推广
  • 生猪价格今日猪价行情关键词优化是什么工作
  • 网站建设公司下载搜索引擎查询
  • 韩国吃秀在哪个网站做直播企业宣传
  • 江西网站建设成都百度
  • 糯米团网站怎么做微信软文范例100字
  • 如何在社交网站上做视频推广seo营销的概念
  • 大连做网站仟亿科技最新域名查询
  • 网站开发实施计划与安排宁波网络推广方式
  • 企业网站建设公司注意哪些问题软件开发外包公司
  • abc网站建设怎么样yandex引擎搜索入口
  • wordpress屏蔽f12广州seo网络优化公司
  • 南宁网站建设推广服务云服务器免费
  • 大数据营销是什么seo站长
  • 建设政府网站的公司乐山网站seo
  • 仿站容易还是建站容易专业做灰色关键词排名
  • 做网站背景音乐管理课程培训
  • 网站建设可以自学吗品牌软文范文
  • 网站风格对比哪里有学计算机培训班
  • 做mla的网站网站优化哪家好
  • 网站注册的账号怎么注销线上营销活动有哪些
  • 国内做进口的电商网站网站推广软件哪个好
  • 谁有做那事的网站百度投诉中心入口
  • 免费单页网站在线制作沈阳seo排名优化教程
  • 廊坊网站建大型网站建站公司
  • 远程桌面做网站sem和seo区别与联系
  • 做贷款网站优化大师有用吗
  • 有没有便宜的网站制作制作网页教程