网络安全JavaSE第六天

7. 数组

7.3.5 数组排序

7.3.5.1 冒泡排序

冒泡排序的思路:相邻两个元素进行比较,如果前面元素比后面元素大就交换位置,每一趟执行完后, 就会得到最大的数。 排序过程分析:

java 复制代码
package com.openlab;
/**
* 冒泡排序
*/
public class BubbleSort {
public static void main(String[] args) {
int[] arr = {6, 9, 1, 5, 2, 3, 8, 4, 7};
print(arr);
// 排序后
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 + 1];
arr[j + 1] = arr[j];
arr[j] = temp;
}
}
}
print(arr);
}
private static void print(int[] arr) {
for (int el : arr) {
System.out.print(el + "\t");
}
System.out.println();
}
}

7.3.5.2 选择排序

选择排序的思路:每次都从剩余元素中找到最小的元素并将其放到有序数组的最后。 排序过程:

代码实现:

java 复制代码
package com.openlab;
/**
* 选择排序
*/
public class SelectSort {
public static void main(String[] args) {
int[] arr = {6, 9, 1, 5, 2, 3, 8, 4, 7};
print(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;
}
}
}
print(arr);
}
private static void print(int[] arr) {
for (int el : arr) {
System.out.print(el + "\t");
}
System.out.println();
}
}

7.3.5.3 插入排序

排序思路:默认第一个元素是有序的,然后从后面元素取出元素也前面的元素进行比较,然后找到合适 的位置结束。 排序过程:

排序实现:

7.3.6 数组查找

7.3.6.1 线性查找

思路是将被查找的元素与数组中的每一个元素从前往后一一匹配,如果能匹配上则找到,否则找不到

java 复制代码
public class LineSearch {
public static void main(String[] args) {
int[] arr = {6, 9, 1, 5, 2, 3, 8, 4, 7};
int key = 8; // 要查找的元素
int index = -1;
for (int i = 0; i < arr.length; i++) {
if (arr[i] == key) {
index = i;
break;
}
}
if (index != -1) System.out.println(arr[index]);
else System.out.println("没找到");
}
}

7.3.6.2 折半查找

也叫二分查找,思路是对定义两个指针分别指向被查找数组的第一个元素和最后一个元素的位置,然后 再定义一个中间指针指向第一个指针加上第二个指针然后除以 2 后的位置。如果被查找的元素小于中间 指针对应的元素,则在左边区域查找,如果被查找的元素大于中间指针对应元素则在右边区域查找。 要实现折半查找,被查找的数组必须有序。

java 复制代码
/**
* 折半查找
*/
public class BinarySearch {
public static void main(String[] args) {
int[] arr = {6, 9, 1, 5, 2, 3, 8, 4, 7};
// 排序
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 tmp = arr[j+1];
arr[j+1] = arr[j];
arr[j] = tmp;
}
}
}
int key = 8; // 被查找的元素
int left = 0; // 左指针
int right = arr.length - 1; // 右指针
int middle = (left + right) / 2; // 中间指针
while (arr[middle] != key) {
if (key < arr[middle]) {
right = middle - 1;
}
if (key > arr[middle]) {
left = middle + 1;
}
if (middle > right) {
middle = -1;
break;
}
middle = (left + right) / 2;
}
System.out.println(arr[middle]);
}
}

练习题:

java 复制代码
import java.util.Scanner;
public class Example01 {
public static void main(String[] args) {
String line1 = input(1);
String line2 = input(2);
/*
// 从字符串 line1 中切出元素
String[] line1Arr = line1.split(" ");
String[] line2Arr = line2.split(" ");
//System.out.println(Arrays.toString(line1Arr));
//System.out.println(Arrays.toString(line2Arr));
// 定义要判断的数组
int[] list1 = new int[Integer.parseInt(line1Arr[0])];
int[] list2 = new int[Integer.parseInt(line2Arr[0])];
// 给数组添加元素
for (int i = 1; i < line1Arr.length; i++) {
list1[i-1] = Integer.parseInt(line1Arr[i]);
}
System.out.println("list1 = " + Arrays.toString(list1));
for (int i = 1; i < line2Arr.length; i++) {
list2[i-1] = Integer.parseInt(line2Arr[i]);
}
System.out.println("list2 = " + Arrays.toString(list2));
*/
//int[] list1 = defineArray(line1);
//int[] list2 = defineArray(line2);
// 判断两个数组是否相同
//boolean flag = equals(list1, list2);
boolean flag = equals(defineArray(line1), defineArray(line2));
System.out.println(flag);
}
/**
* 从接收到的字符串中截取需要的数据到数组中并返回
* @param line 需要截取字符串
* @return 返回最终的整型数组
*/
public static int[] defineArray(String line) {
// 判断接收到的字符串是否为空
if (line==null || line.isBlank()) {
System.out.println("你输入的是空。程序退出!");
System.exit(1);
}
// 从字符串 line1 中切出元素
String[] lineArr = line.split(" ");
// 定义要判断的数组
int[] list1 = new int[Integer.parseInt(lineArr[0])];
// 给数组添加元素
for (int i = 1; i < lineArr.length; i++) {
list1[i-1] = Integer.parseInt(lineArr[i]);
}
return list1;
}
/**
* 接收用户输入
* @param n 输入的编号
* @return 返回最终用户输入值
*/
public static String input(int n) {
Scanner sc = new Scanner(System.in);
System.out.println("Enter list"+n+":");
return sc.nextLine();
}
public static boolean equals(int[] list1, int[] list2) {
// 1. 判断两个数组的元素个数是否相同,如果不同则直接返回 false
if (list1.length != list2.length) {
return false;
}
for (int i = 0; i < list1.length; i++) {
if (list1[i] != list2[i]) {
return false;
}
}
return true;
}
}

作业练习:

相关推荐
xiaoshiguang34 小时前
LeetCode:222.完全二叉树节点的数量
算法·leetcode
爱吃西瓜的小菜鸡4 小时前
【C语言】判断回文
c语言·学习·算法
别NULL4 小时前
机试题——疯长的草
数据结构·c++·算法
TT哇4 小时前
*【每日一题 提高题】[蓝桥杯 2022 国 A] 选素数
java·算法·蓝桥杯
ZSYP-S5 小时前
Day 15:Spring 框架基础
java·开发语言·数据结构·后端·spring
yuanbenshidiaos5 小时前
C++----------函数的调用机制
java·c++·算法
唐叔在学习6 小时前
【唐叔学算法】第21天:超越比较-计数排序、桶排序与基数排序的Java实践及性能剖析
数据结构·算法·排序算法
ALISHENGYA6 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(switch语句)
数据结构·算法
chengooooooo6 小时前
代码随想录训练营第二十七天| 贪心理论基础 455.分发饼干 376. 摆动序列 53. 最大子序和
算法·leetcode·职场和发展
jackiendsc6 小时前
Java的垃圾回收机制介绍、工作原理、算法及分析调优
java·开发语言·算法