当前位置: 首页 > news >正文

Java基础 3.29

1.数组的相关注意事项

错误示范一

String strs[] = new String[2]{"a", "b"};

正确示范一

String strs[] = new String[]{"a", "b"};

 让JVM自己判断有几个数据,无需再其中写明有几组数据

错误示范二

String strs[] = new String{"a", "b"};

正确示范二

String strs[] = {"a", "b"};

2.数组相关练习

/*
已知有个升序数组,要求插入一个元素,该数组顺序依然是升序的
*/
import java.util.Scanner;
public class ArrayHomework01 {
	public static void main(String[] args) {
		Scanner myScanner = new Scanner(System.in);
		int arr[] = {10, 12, 45, 90};
		int arr2[] = new int[arr.length + 1];
		System.out.println("请输入你要添加的数字");
		int addNum = myScanner.nextInt();
		for (int j = 0; j < arr.length; j++) {//直接扩容
			arr2[j] = arr[j];
			arr2[j+1] = addNum;
		}
		arr = arr2;//将原数组地址定位到扩容后的数组的地址
		int temp = 0;
		for (int i = 0; i < arr.length; i++) {//再用冒泡算法重新排列
			int times = arr.length - 1;
			for (int j = 0; j < times; j++) {
				if (arr[j] > arr[j+1]) {
					temp = arr[j];
					arr[j] = arr[j+1];
					arr[j+1] = temp;
				}
			}
		}
		
		for (int i = 0; i < arr.length; i++) {//输出排列完后的数组
			System.out.print(arr[i] + " ");
		}
		
	}
}
//解法2
public class ArrayHomework01 {
	public static void main(String[] args) {
		int arr[] = {10, 12, 45, 90};
		int insertNum = 23;
		int index = -1;
		for (int i = 0; i < arr.length; i++) {
			if (insertNum <= arr[i]) {
				index = i;
				break;
			} 
		} 

		if (index == -1) {
			index = arr.length;
		}
		//System.out.print(index);
		int arrNew[] = new int[arr.length + 1];

		for (int i = 0, j = 0; i < arrNew.length; i++) {
			if (i != index) {
				arrNew[i] = arr[j];
				j++;
			} else {
				arrNew[i] = insertNum;
			}
		}
		arr = arrNew;
		for (int i = 0; i < arr.length; i++) {
			System.out.print(arr[i] + " ");
		}
	}
}

相关文章:

  • C++11·部分重要语法II
  • android11关机安卓充电的UI定制化
  • 练习题:110
  • Mybatis逆向工程
  • 【商城实战(94)】构建高并发的负载均衡与集群架构
  • RedHatLinux(2025.3.22)
  • 解决 macOS (M1 Pro) 上使用 Vite 进行 Build 打包时 Node 进程内存溢出的问题
  • 复现GitHub上`https://github.com/tobiasfshr/map4d`这个项目
  • Android学习总结之ContentProvider跨应用数据共享
  • 无需docker三步安装deepseek可视化操作软件-Open-WebUI
  • RabbitMQ消息相关
  • #C8# UVM中的factory机制 #S8.5# 对factory机制的重载进一步思考(二)
  • Hyperlane:Rust Web开发的未来,释放极致性能与简洁之美
  • 2025-3-29算法打卡
  • epoll 和ractor模型学习
  • Docker 的实质作用是什么
  • Blender多摄像机怎么指定相机渲染图像
  • 《数据结构:单链表》
  • 最常使用的现代C++新特性介绍
  • 复古半色调褶皱照片效果ps特效滤镜样机 Halftone Crumpled Paper Effect
  • 澎湃读报丨解放日报9个版聚焦:上海,加快建成具有全球影响力的科技创新高地
  • 杨国荣︱学术上的立此存照——《故旧往事,欲说还休》读后
  • 大理杨徐邱再审上诉案宣判:驳回上诉,维持再审一审判决
  • 上海出台灵活就业人员公积金新政:不限户籍、提取自由,6月起施行
  • 中国海警局新闻发言人就菲律宾非法登临铁线礁发表谈话
  • 全球首台环形CT直线加速器在沪正式开机,系我国自主研发