网络安全JavaSE第六天

7. 数组

7.3.5 数组排序

7.3.5.1 冒泡排序

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

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 选择排序

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

代码实现:

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 线性查找

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

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 后的位置。如果被查找的元素小于中间 指针对应的元素,则在左边区域查找,如果被查找的元素大于中间指针对应元素则在右边区域查找。 要实现折半查找,被查找的数组必须有序。

/**
* 折半查找
*/
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]);
}
}

练习题:

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;
}
}

作业练习:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/809081.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

pyside6自定义部件库和软件框架的建设记录

一、自定义部件库 原则上尽量做到前后端分离&#xff0c;接口方便&#xff0c;复制简单。 1、单选框部件 # encoding: utf-8 ################################################### # 自定义的单选框 #################################################### 对外…

基于模型预测算法的含储能微网双层能量管理模型

基于模型预测算法的含储能微网双层能量管理模型 文章目录 基于模型预测算法的含储能微网双层能量管理模型一、项目介绍二、源程序下载 一、项目介绍 代码主要做的是一个微网双层优化调度模型&#xff0c;微网聚合单元包括风电、光伏、储能以及超级电容器&#xff0c;在微网的运…

Go语言mac环境搭建详解

Go语言mac环境搭建详解见视频&#xff0c;视频下方也有讲解具体的操作步骤。 Golang Mac电脑环境搭建、开发工具Vscode配置 Go语言mac环境搭建步骤如下&#xff1a; 1、下载安装Golang Go官网下载地址&#xff1a;https://golang.org/dl/ Go官方镜像站&#xff08;推荐&…

Windows下如何确定DLL动态库是32位还是64位

文章目录 Windows下如何确定DLL动态库是32位还是64位使用dumpbin工具可能出现的问题结果输出内容 Windows下如何确定DLL动态库是32位还是64位 使用dumpbin工具 dumpbin.exe通常位于Visual Studio的安装目录下的VC\bin或VC\Tools\MSVC\<version>\bin\Hostx64\x64 比如&am…

海山数据库(He3DB)Redis技术实践:继承开源Redis精髓,强化升级企业级服务

数字化转型中的企业数据的处理速度和效率直接关系到企业的竞争力&#xff0c;Redis作为业界广泛使用的开源键值对存储系统&#xff0c;以其卓越的性能和丰富的数据结构&#xff0c;成为了众多开发者和企业的首选。然而&#xff0c;近期Redis开源社区对Redis协议进行了变更&…

电力综合自动化系统对电力储能技术的影响有哪些?

电力综合自动化系统对电力储能技术的影响主要体现在以下几个方面&#xff1a; 提高能源利用效率&#xff1a;电力综合自动化系统通过优化调度和能量管理&#xff0c;可以实现储能设备的有效利用&#xff0c;提高能源利用效率。在电力系统中&#xff0c;储能设备可以有效地平抑风…

贪心算法:排列算式

题目描述 给出n数字&#xff0c;对于这些数字是否存在一种计算顺序&#xff0c;使得计算过程中数字不会超过3也不会小于0&#xff1f; 输入描述: 首行给出一个正整数t,(1≤t≤1000)代表测试数据组数每组测试数据第一行一个正整数n,(1≤n≤500)第二行包含n个以空格分隔的数字…

Flutter - flutter_gen 资源管理

引言&#xff1a; 在开发 Flutter 应用时&#xff0c;我们经常需要使用各种静态资源&#xff0c;如图片、字体和音频等。如何有效地管理和加载这些资源呢&#xff1f;本篇博客将以图片为例带你解密 Flutter 项目中是如何管理资源地。 assets 加载资源 具体文件名引入 在工程…

STC89C52学习笔记(九)

STC89C52学习笔记&#xff08;九&#xff09; 综述&#xff1a;本文主要介绍了蜂鸣器、蜂鸣器如何使用以及如何利用蜂鸣器播放不同频率声音。 一、蜂鸣器 1.定义和作用 电信号→声音信号&#xff0c;常用来产生按键音和报警音。 2.分类 有源&#xff1a;自带振荡器&#…

机器学习 -- 端到端的机器学习项目

场景 我们将一个端到端的项目&#xff08;一个从开始到结束包含了所有必要步骤和组件的完整项目&#xff09;案例&#xff0c;步骤大概有&#xff1a; 1.观察大局。 2.获得数据。 3.从数据探索和可视化中获得洞见。 4.机器学习算法的数据准备。 5.选择和训练模型。 6.微调模型…

git lfs 大文件管理

简介 git-lfs 是 Git Large File Storage 的缩写&#xff0c;是 Git 的一个扩展&#xff0c;用于处理大文件的版本控制。 它允许你有效地管理和存储大型二进制文件&#xff0c;而不会使 Git 仓库变得过大和不稳定。以下是一些与 git-lfs 相关的常见命令和解释&#xff1a; 常…

unity——Button组件单击双击长按功能

1.实现单击、双击、长按功能 using UnityEngine; using UnityEngine.Events; using UnityEngine.EventSystems; public class ButtonControl_Click_Press_Double : MonoBehaviour, IPointerClickHandler, IPointerDownHandler, IPointerUpHandler, IPointerExitHandler {publi…

紫光同创 ----- 集创赛 ---- 点亮LED

目录 一. 安装软件&#xff1a; 1. 按照安装手册一步一步走 2. 等.... 3. 桌面图标 二. 创建工程 1. 双击PDS 2. 点击新建工程 New Project 3. 弹出如下界面 点击 -->> Next 4. 选择工程路径和名称 5. 选择工程类型 6. 剩下的全部next &#xff08;直到…

idea: 没有 new java class

如图&#xff1a; 解决&#xff1a; 右键点击--> Mark Directory as --> Sources Root ok

python---3--sort、lambdalen(list1)、sorted_numbers = sorted(numbers)、list.sort()

学习目标&#xff1a; lambda len(list1) sorted_numbers sorted(numbers)list.sort() 目录 学习目标&#xff1a; 学习内容&#xff1a; 匿名函数 lambda表达式 lambda [参数]: 函数 不需要return len(list1) sorted_numbers sorted(numbers) list.sort(keyNone, r…

ActiveMQ入门案例(queue模式和topic模式)

目录 前言&#xff1a;为什么使用消息中间件&#xff1f; 异步通信 缓冲 解耦 前提&#xff1a;安装并启动activemq 一、点对点&#xff08;point to point&#xff0c; queue&#xff09; 1.1 创建maven项目 1.2 Pom依赖 1.2 JmsProduce 消息生产者 1.3 JmsConsumer…

背 单 词 (考研词汇闪过)

单词&#xff1a; 买考研词汇闪过 研究艾宾浩斯遗忘曲线 https://www.bilibili.com/video/BV18Y4y1h7YR/?spm_id_from333.337.search-card.all.click&vd_source5cbefe6dd70d6d84830a5891ceab2bf9 单词方法 闪记背两排&#xff08;5min&#xff09;重复一遍&#xff08;2mi…

Pixel-GS:用于3D高斯溅射的具有像素感知梯度的密度控制

Pixel-GS: Density Control with Pixel-aware Gradient for 3D Gaussian Splatting Pixel-GS&#xff1a;用于3D高斯溅射的具有像素感知梯度的密度控制 Zheng Zhang  Wenbo Hu†  Yixing Lao   老宜兴市郑张文博胡 † Tong He  Hengshuang Zhao† 赵同和恒双 †1122113311 …

BTS441RGATMA1 N沟道 43V 17A高侧电源开关芯片 英飞凌

BTS441RGATMA1是一款由Infineon Technologies制造的高侧开关电源芯片。 直 接 联 系 客 服 价 格 比 商 城 下 单 更 便 宜 BTS441RGATMA1具有以下功能&#xff1a; 高端电源开关&#xff1a;BTS441RGATMA1是一种N通道功率场效应晶体管&#xff08;FET&#xff09;&#xff…

图像处理与视觉感知---期末复习重点(7)

文章目录 一、图像压缩1.1 三种冗余1.2 模型1.3 信息测量 二、无误差压缩2.1 哈夫曼编码2.1.1 步骤2.1.2 例题 2.2 算术编码 三、变换编码 一、图像压缩 1.1 三种冗余 1. 三种基本的是数据冗余为&#xff1a;编码冗余、像素间冗余、心理视觉冗余。 2. 编码冗余&#xff1a;如果…