当前位置: 首页 > 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
  • 文天祥与“不直人间一唾轻”的元将唆都
  • 俄乌战火不熄,特朗普在梵蒂冈与泽连斯基会晤后口风突变
  • 秦洪看盘|浮现新预期,存量资金积极调仓
  • 海南儋州市委副书记任延新已赴市人大常委会履新
  • 来论|如何看待韩企在美申请“饺子”专利
  • 著名统计学家、北京工业大学应用数理学院首任院长王松桂逝世