class ArrDemo5{
public static void main(String[] args){
int[] arr = {4,34,56,65,78,87,98,100};
//int index = getIndex(arr, 56);
//System.out.println(index);
//bubbleSort(arr);
//selectSort(arr);
int index = halfSearch(arr, 77);
System.out.println(index);
}
//二分查找法,折半查找法
public static int halfSearch(int[] arr, int key){
int min = 0;//记录数组起始下标
int max = arr.length-1;//记录数组最后下标
int mid = (min+max)/2;//计算中间下标
while(key != arr[mid]){
if(key > arr[mid]){
min = mid + 1;
}
if(key < arr[mid]){
max = mid - 1;
}
if(min > max){
return -1;
}
//重新计算中间下标
mid = (min + max)/2;
}
return mid;
}
//一般查找
public static int getIndex(int[] arr, int key){
for(int i=0; i<arr.length; i++){
if(key == arr[i]){
return i;
}
}
return -1;
}
//选择排序
public static void selectSort(int[] arr){
for(int i=0; i<arr.length-1; i++){
for(int j=i+1; j<arr.length; j++){
if(arr[i] > arr[j]){
//int temp = arr[j];
//arr[j] = arr[i];
//arr[i] = temp;
swap(arr, i, j);
}
}
}
printArr(arr);
}
//冒泡排序
public static void bubbleSort(int[] arr){
for(int i=arr.length-1;i>0; i--){
for(int j=0; j<i; j++){
if(arr[j] > arr[j+1]){
//int temp = arr[j+1];
//arr[j+1] = arr[j];
//arr[j] = temp;
swap(arr, i, j);
}
}
}
printArr(arr);
}
//打印数组
public static void printArr(int[] arr){
for(int i=0; i<arr.length; i++){
System.out.println(arr[i]);
}
}
//交换数组中两个位置
public static void swap(int[] arr, int from, int to){
int temp = arr[from];
arr[from] = arr[to];
arr[to] = temp;
}
}
冒泡排序
//冒泡排序
class asd{
public static void main(String[] args){
int[] arr = { 3, 44, 38, 5, 47, 15, 36, 26, 27, 2, 46, 4, 19, 50, 48 };
// 统计比较次数
int count = 0;
// 第一轮比较
for (int i = 0; i < arr.length - 1; i++) {
// 第二轮比较
for (int j = 0; j < arr.length - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
// 交换位置
int temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
count++;
}
System.out.println(count);
}
for(int i = 0;i < arr.length-1;i++)
{
System.out.print(arr[i]+" ");
}
}
}
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/114848.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...