第二天算法设计
选择排序
需求:
排序前:{4,6,8,7,9,2,10,1}
排序后:{1,2,4,5,7,8,9,10}
算法设计:
Selection类:
package suanfa;
public class Selection {
//对数组a中的元素进行排序
public static void sort(Comparable[] a){
for(int i =0;i<a.length-1;i++){
int minIdex = i;
for(int j = i+1;j<a.length;j++){
if(greater(a[minIdex],a[j])){
minIdex = j;
}
}
exch(a,i,minIdex);
}
}
//比较v元素是否大于w元素
private static boolean greater(Comparable v,Comparable w){
return v.compareTo(w)>0;
}
//数组元素i和j交换位置
private static void exch(Comparable[] a,int i,int j ){
Comparable temp;
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
SelectionTest类:
package suanfa;
import java.util.Arrays;
public class SelectionTest {
public static void main(String[] args) {
Integer[] a={4,6,8,7,9,10,1};
Selection.sort(a);
System.out.println(Arrays.toString(a));
}
}
录制: untitled2 – Selection.java
录制文件:https://meeting.tencent.com/crm/Kwqmpbqjd6
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本