一:冒泡排序
/*
* 数组排序之冒泡排序:
* 相邻元素两两比较,大的往后放,第一次完毕,最大值出现在了最大索引处
*
* 引申:
* 利用冒泡排序法,可以获取一个数组的最大值(先冒泡排序,取最后一个值)和最小值(调用冒泡排序,取第一个值)
*/
public class ArrayDemo {
public static void main(String[] args) {
// 定义一个数组
int[] arr = { 24, 69, 80, 57, 13 };
System.out.println("排序前:");
printArray(arr); //由于可能有多个数组要排序,所以要写成方法
bubbleSort(arr);
System.out.println("排序后:");
printArray(arr);
} //冒泡排序代码
public static void bubbleSort(int[] arr){
for (int x = 0; x < arr.length - 1; x++) {//外循环控制比较的次数(arr.length-1)轮
for (int y = 0; y < arr.length - 1 - x; y++) {// arr.length - 1是为了防止数据越界,// arr.length - 1 - x是为了减少比较的次数
if (arr[y] > arr[y + 1]) {//前面的数大于后边的数。交换
int temp = arr[y];
arr[y] = arr[y + 1];
arr[y + 1] = temp;
}
}
}
} // 遍历功能
public static void printArray(int[] arr) {
System.out.print("[");
for (int x = 0; x < arr.length; x++) {
if (x == arr.length - 1) {
System.out.print(arr[x]+"]");
} else {
System.out.print(arr[x] + ", ");
}
}
}
}

二:选择排序

/*
* 数组排序之选择排序:
* 从0索引开始,依次和后面元素比较,小的往前放,第一次完毕,最小值出现在了最小索引处
*/
public class ArrayDemo {
public static void main(String[] args) {
// 定义一个数组
int[] arr = { 24, 69, 80, 57, 13 };
System.out.println("排序前:");
printArray(arr); //用方法改进
selectSort(arr);
System.out.println("排序后:");
printArray(arr); } public static void selectSort(int[] arr){
for(int x=0; x<arr.length-1; x++){//总共进行arr.length-1轮
for(int y=x+1; y<arr.length; y++){
if(arr[y] <arr[x]){//如果后面的数小于前面的数,交换,始终使得前面的为小值
int temp = arr[x];
arr[x] = arr[y];
arr[y] = temp;
}
}
}
} // 遍历功能
public static void printArray(int[] arr) {
System.out.print("[");
for (int x = 0; x < arr.length; x++) {
if (x == arr.length - 1) {
System.out.print(arr[x]);
} else {
System.out.print(arr[x] + ", ");
}
}
System.out.println("]");
}
}

三:二分查找

/*
* 查找:
* 基本查找:数组元素无序(从头找到尾)
* 二分查找(折半查找):数组元素有序
*
* 分析:
* A:定义最大索引,最小索引
* B:计算出中间索引
* C:拿中间索引的值和要查找的值进行比较
* 相等:就返回当前的中间索引
* 不相等:
* 大 左边找
* 小 右边找
* D:重新计算出中间索引
* 大 左边找
* max = mid - 1;
* 小 右边找
* min = mid + 1;
* E:回到B
*/
public class ArrayDemo {
public static void main(String[] args) {
//定义一个数组
int[] arr = {11,22,33,44,55,66,77}; //写功能实现
int index = getIndex(arr, 33);
System.out.println("index:"+index); //假如这个元素不存在后有什么现象呢?
index = getIndex(arr, 333);
System.out.println("index:"+index);//-1
} public static int getIndex(int[] arr,int value){
//定义最大索引,最小索引
int max = arr.length -1;
int min = 0; //计算出中间索引
int mid = (max +min)/2; //拿中间索引的值和要查找的值进行比较
while(arr[mid] != value){//while实现循环
if(arr[mid]>value){//大
max = mid - 1;//左边找
}else if(arr[mid]<value){//小
min = mid + 1;//右边找
} //加入判断
if(min > max){//找不到
return -1;
} mid = (max +min)/2;//重新取新一轮数组的中间值
} return mid;//arr[mid] = value
}
}

最新文章

  1. 读取java目录中相同目录、相同名称的文件
  2. 四元数quaternion
  3. 安装android studio
  4. AX ERP 真正的自动批处理
  5. AppSetting ,connectionStrings配置节
  6. apache 配置网站目录,虚拟目录,新端口
  7. 使用recordmydesktop进行屏幕录像
  8. mysql数据库快速入门(1)
  9. 【转】一文掌握 Linux 性能分析之网络篇(续)
  10. C语言按位运算符
  11. SpringBoot +Jpa+ Hibernate+Mysql工程
  12. hive的jdbc使用
  13. 【LOJ】#2384. 「HNOI2013」切糕
  14. ilmerge工具合并多个DLL或EXE
  15. [转]Ubuntu使用Wireshark找不到interface的解决方法
  16. HDU 1465 不容易系列之一 (错排公式+容斥)
  17. 【转载】RecyclerView源码解析
  18. .NET程序如何启动?
  19. flask factory
  20. Selenium2学习(十七)-- js处理日历控件(修改readonly属性)

热门文章

  1. 在Spring Boot框架下使用WebSocket实现聊天功能
  2. Mac OS: How to keep network connection alive after sleep
  3. pthon核心编程-读书笔记:知识点摘录与总结(方便理解和快速记忆)
  4. 使用Linux脚本更新Weblogic部署的应用程序
  5. Android图表库MPAndroidChart(六)——换一种思考方式,水平条形图的实现过程
  6. Gazebo機器人仿真學習探索筆記(六)工具和实用程序
  7. Premake可生成vcxproj.filters
  8. N个整数(数的大小为0-255)的序列,把它们加密为K个整数(数的大小为0-255).再将K个整数顺序随机打乱,使得可以从这乱序的K个整数中解码出原序列。设计加密解密算法,且要求K&lt;=15*N.
  9. [shiro学习笔记]第四节 使用源代码生成Shiro的CHM格式的API文档
  10. VisualStudio2010配置OpenCV的一种一劳永逸的方法