java实现 排序算法(鸡尾酒排序&选择排序&插入排序&二分插入排序)
1、鸡尾酒排序算法
源程序代码:
package com.SuanFa;
public class Cocktial {
public static void main(String[] args) {
// TODO Auto-generated method stub
cooktailSort cook=new cooktailSort();
int[] A={1,2,3,8,4,0,5,34,12,67,35,9,45,443,454,242,343};
int n=A.length;
cook.cooktailSort(A, n);
System.out.println("输出排序结果");
for(int i=0;i<A.length;i++){
System.out.printf(A[i]+" ");
}
}
}
class cooktailSort{
void Swap(int[] A,int i,int j){
int temp=A[i];
A[i]=A[j];
A[j]=temp;
}
void cooktailSort(int[] A,int n){
int left=0;
int right=n-1;
while(left<right){
for(int i=left;i<right;i++){
if(A[i]>A[i+1]){
Swap(A,i,i+1);
}
}
right--;
for(int i=right;i>left;i--){
if(A[i-1]>A[i]){
Swap(A,i-1,i);
}
}
left++;
}
}
}
2、选择排序算法
程序代码
package com.SuanFa;
public class XuanZe {
public static void main(String[] args) {
// TODO Auto-generated method stub
selectSort sort=new selectSort();
int[] A={23,34,3,45,45,32,55,12};
int n=A.length;
sort.select(A, n);
System.out.println("输出排序结果");
for(int i=0;i<n;i++){
System.out.printf(A[i]+" ");
}
}
}
class selectSort{
void Swap(int[] A,int i,int j){
int temp=A[i];
A[i]=A[j];
A[j]=temp;
}
void select(int[] A,int n){
for(int i=0;i<n-1;i++){
int min=i;
for(int j=i+1;j<n;j++){
if(A[j]<A[min]){
min=j;
}
}
if(min!=i){
Swap(A,min,i);
}
}
}
}
3、插入排序算法
程序代码
package com.SuanFa;
public class ChaRu {
public static void main(String[] args) {
// TODO Auto-generated method stub
cha c=new cha();
int[] A={2,3,3,5,21,65,23,43};
int n=A.length;
c.insertSoet(A, n);
for(int i=0;i<n;i++){
System.out.printf("%d ",A[i]);
}
}
}
class cha{
void insertSoet(int A[],int n){
for(int i=1+1;i<n;i++){
int get=A[i];
int j=i-1;
while(j>0&&A[j]>get){
A[j+1]=A[j];
j--;
}
A[j+1]=get;
}
}
}
4、二分插入排序算法
程序代码
package com.SuanFa;
public class erfengChaRu {
public static void main(String[] args) {
// TODO Auto-generated method stub
test1 sort=new test1();
int[] A={23,34,3,45,45,32,12,55,12,12};
int n=A.length;
sort.insertSortDic(A, n);
System.out.println("输出排序结果");
for(int i=0;i<n;i++){
System.out.printf(A[i]+" ");
}
}
}
class test1{
void insertSortDic(int A[],int n){
for(int i=1;i<n;i++){
int get=A[i];
int left=0;
int right=i-1;
while(left<=right){
int mid=(left+right)/2;
if(A[mid]>get){
right=mid-1;
}else
left=mid+1;
}
for(int j=i-1;j>=left;j--){
A[j+1]=A[j];
}
A[left]=get;
}
}
}
5、堆排序算法
java实现 排序算法(鸡尾酒排序&选择排序&插入排序&二分插入排序)的更多相关文章
- Java常见排序算法之直接选择排序
在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...
- Java排序算法之直接选择排序
Java排序算法之直接选择排序 基本过程:假设一序列为R[0]~R[n-1],第一次用R[0]和R[1]~R[n-1]相比较,若小于R[0],则交换至R[0]位置上.第二次从R[1]~R[n-1]中选 ...
- 排序算法系列:选择排序算法JAVA版(靠谱、清晰、真实、可用、不罗嗦版)
在网上搜索算法的博客,发现一个比较悲剧的现象非常普遍: 原理讲不清,混乱 啰嗦 图和文对不上 不可用,甚至代码还出错 我总结一个清晰不罗嗦版: 原理: 从数组头元素索引i开始,寻找后面最小的值(比i位 ...
- 【排序算法】直接选择排序算法 Java实现
基本思想 直接选择排序是从无序区选一个最小的元素直接放到有序区的最后. 初始状态:无序区为a[1...n],有序区为空. 第一次排序:在无序区a[1...n]中选出最小的记录a[k],将它与有序区的第 ...
- 排序算法入门之选择排序-Java实现
本文参考http://blog.csdn.net/m0_37568091/article/details/78023705 选择排序是先从对象数组中选出最小的放在第一个位置,再从剩下的元素中选择次小的 ...
- 常见的排序算法(直接插入&选择排序&二分查找排序)
1.直接插入排序算法 源码: package com.DiYiZhang;/* 插入排序算法 * 如下进行的是插入,排序算法*/ public class InsertionSort { pub ...
- C语言中的排序算法--冒泡排序,选择排序,希尔排序
冒泡排序(Bubble Sort,台湾译为:泡沫排序或气泡排序)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没 ...
- JS排序算法--冒泡排序和选择排序
在我们JS语法当中,数据类型中的复杂数据类型,有一项我们常用的数组数据类型,其中存储的数据有时是乱序的,需要排序,我们有多种方法,最简单的肯定是 :变量.sort(fonction(a,b){a> ...
- 排序系列 之 简单选择排序及其改进算法 —— Java实现
简单选择排序算法: 基本思想: 在待排序数据中,选出最小的一个数与第一个位置的数交换:然后在剩下的数中选出最小的数与第二个数交换:依次类推,直至循环到只剩下两个数进行比较为止. 实例: 0.初始状态 ...
- 冒泡排序算法和简单选择排序算法的js实现
之前已经介绍过冒泡排序算法和简单选择排序算法和原理,现在有Js实现. 冒泡排序算法 let dat=[5, 8, 10, 3, 2, 18, 17, 9]; function bubbleSort(d ...
随机推荐
- LOJ #2541「PKUWC2018」猎人杀
这样$ PKUWC$就只差一道斗地主了 假装补题补完了吧..... 这题还是挺巧妙的啊...... LOJ # 2541 题意 每个人有一个嘲讽值$a_i$,每次杀死一个人,杀死某人的概率为$ \fr ...
- Ajax——从服务器获取各种文件
ajax.js内容 function ajax(url,fnWin,fnFaild){ //1.创建ajax对象 var xhr = window.XMLHttpRequest ? new XMLHt ...
- Maven 分模块,启动父工程时异常
1.1 运行方式 Maven方式:命令的 方式1:运行父工程.父工程将各个子模块聚合到一起.将ssh-web打war包发布到tomcat 方式2:直接运行web工程 其他方式:传统的, 部署到to ...
- Create C++ Class
创建“目标物体”,是世界场景中的一个物体,当玩家经过时,可以将它拾起,并带至某处 选择Actor为父类,创建FPSObjectiveActor类 注:点击公有按钮就会把头文件放入Public文件夹 ...
- C++11 override 和 final 关键字
C++11之前,一直没有继承控制关键字.禁用一个类的进一步衍生是可能的但也很棘手.为避免用户在派生类中重载一个虚函数,你不得不向后考虑. C++ 11添加了两个继承控制关键字:override和fin ...
- 使用 ffmpeg nginx rtmp 搭建实时流处理平台
环境: ubuntu 16.04 问题引入: 使用 opencv 获取摄像头数据帧, 进行处理之后(如进行 keypoint 识别), 将 opencv 中图像的 Mat类型转化为 ffmpeg 的 ...
- 判断HDFS文件是否存在
hadoop判断文件是否存在 在shell中判断一个HDFS目录/文件是否存在 直接看shell代码: hadoop fs -test -e /hdfs_dirif [ $? -ne 0 ]; the ...
- codeforces411div.2
每日CF: 411div2 Solved A CodeForces 805A Fake NP Solved B CodeForces 805B 3-palindrome Solved C CodeFo ...
- hibernate映射关系(多对多)
Student与Teacher关系多对多(只建了2个实体类) public class Student { private int id; private String name; private S ...
- Windows中查看端口占用及关闭对应进程
开始--运行--cmd 进入命令提示符 输入netstat -ano 即可看到所有连接的PID,之后在任务管理器(右键电脑屏幕的状态栏即可找到)中找到这个PID所对应的程序.如果任务管理器中没有PID ...