java基础的详细了解第四天
作者:zsr6135 发布时间:2022-11-25 07:24:51
标签:java,基础,详解
1、数组
数组的引用传递
public class TestDemo1{
public static void main(String args[]){
int data[] = null;
data = new int [3];
data[0] = 10;//第一个元素
data[1] = 20;//第二个元素
data[2] = 30;//第三个元素
}
}
public class TestDemo1{
public static void main(String args[]){
int data[] = null;
int temp[] = null;
data = new int [3];
data[0] = 10;//第一个元素
data[1] = 20;//第二个元素
data[2] = 30;//第三个元素
temp = data;
temp[0] = 99;
for(int i=0 ;i < temp.length ; i++){
System.out.println(temp[i]);
}
}
}
引用传递分析都是一个套路,不同的堆被同一个栈内存所指向。
数组的静态初始化
public class TestDemo2{
public static void main(String args[]){
//数组静态初始化的两种方式
//简化格式
int data [] = {1,2,3};
//完整格式
int data [] = new int []{1,2,3};
}
}
数组的最大缺点:长度固定。
数组与方法的调用
public class TestDemo2{
public static void main(String args[]){
int data [] = new int []{1,2,3,4,5};
printfArray(data);//int temp [] = data;
}
//定义一个专门用于数组输出的方法
public static void printfArray(int temp[]){
for(int i = 0; i < temp.length; i++){
System.out.println(temp[i] + "、");
}
}
}
方法返回数组
public class TestDemo2{
public static void main(String args[]){
int data [] = init();//接受数组
printfArray(data);//int temp [] = data;
}
//此时的方法希望可以返回一个数组类型,所以
//返回值类型定义为整型数组
public static int[] init(){
return new int []{1,2,3,4,5};
}
//定义一个专门用于数组输出的方法
public static void printfArray(int temp[]){
for(int i = 0; i < temp.length; i++){
System.out.println(temp[i] + "、");
}
}
}
扩大数组的内容
public class TestDemo2{
public static void main(String args[]){
int data [] = init();//接受数组
inc(data);//扩大数组的内容
printfArray(data);//int temp [] = data;
}
//此时的方法希望可以返回一个数组类型,所以
//返回值类型定义为整型数组
public static int[] init(){
return new int []{1,2,3,4,5};
}
public static void inc(int arr[]){//没有返回值
for(int i = 0 ; i<arr.length ; i++){
arr[i] *= 2;
}
}
//定义一个专门用于数组输出的方法
public static void printfArray(int temp[]){
for(int i = 0; i < temp.length; i++){
System.out.println(temp[i] + "、");
}
}
}
Java对数组的支持
在java本身的类库中也提供有对于数组相关的方法。
1、数组的排序:java.util.Arrays.sort(数组名称)
public class TestDemo3{
public static void main(String args[]){
int data [] = new int [] {12,3,54,23,64,11};
java.util.Arrays.sort(data);
for(int i = 0;i < data.length ; i++){
System.out.println(data[i]);
}
}
}
2、数组的拷贝:指的是将一个数组的部分内容替换掉另一个数组的部分内容
方法:System.arraycopy(源数组名称,源数组开始,目标数组名称,目标数组开始点,拷贝长度);
数组的数据分析
public class TestDemo3{
public static void main(String args[]){
int data [] = new int [] {12,3,54,23,64,11};
int max = data[0];
int min = data[0];
int sum = 0;
for(int i = 0; i < data.length ; i++){
sum += data[i];
if(data[i]>max){
max = data[i];
}
if(data[i]<min){
min = data[i];
}
}
System.out.println("max = " + max);//求最大值
System.out.println("min = " + min);//求最小值
System.out.println("sum = " + sum);//求总和
System.out.println("average = " + sum/(double)data.length);//求平均值
}
}
数组排序
发现最终要进行循环的次数就是N^(n-1),时间复杂度高。
public class TestDemo4{
public static void main(String args[]){
int data [] = new int [] {9,8,5,6,4,2,1,0,3,7};
sort(data);
printfArray(data);
}
public static void sort(int arr[]){//实现数组的升序排序
for(int i = 0 ;i < arr.length - 1 ; i++){
//控制循环的次数
for(int j = 0 ; j < arr.length - i - 1; j++){
if(arr[j]>arr[j+1]){
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
//定义一个专门用于数组输出的方法
public static void printfArray(int temp[]){
for(int i = 0; i < temp.length; i++){
System.out.println(temp[i] + "、");
}
}
}
数组的转置
public class TestDemo4{
public static void main(String args[]){
int data [] = new int [] {9,8,7,6,5,4,3,2,1,0};
reverse(data);
printfArray(data);
}
public static void reverse(int arr[]){
int center = arr.length / 2;//转换次数
int head = 0;//头部索引
int tail = arr.length - 1;//尾部索引
for(int i = 0 ; i < center ; i++){
int temp = arr[head];
arr[head] = arr[tail];
arr[tail] = temp;
head ++;tail --;
}
}
//定义一个专门用于数组输出的方法
public static void printfArray(int temp[]){
for(int i = 0; i < temp.length; i++){
System.out.print(temp[i] + "、");
}
}
}
public class TestDemo5{
//二维数组转置
public static void main(String args[]){
int data [][] = new int [][] {{9,8,7},{6,5,4},{3,2,1}};
reverse(data);
printfArray(data);
}
public static void reverse(int arr[][]){
int count = arr.length;//转换次数
System.out.println(count);
for(int i = 0 ; i < arr.length ; i++){
for(int j = i; j < arr.length; j++){
if(i != j){
int temp = arr[i][j];
arr[i][j] = arr[j][i];
arr[j][i] = temp;
}
}
}
}
//定义一个专门用于数组输出的方法
public static void printfArray(int temp[][]){
for(int i = 0; i < temp.length; i++){
for(int j = 0 ; j < temp[i].length ; j++){
System.out.print(temp[i][j] + "、");
}
System.out.println();
}
}
}
数组的二分查找法
要求你在一个指定的数组之中查询一个数据的位置。
普通的查找的时间复杂度是n.
public class TestDemo6{
//二分查找
public static void main(String args[]){
int data [] = new int [] {1,2,3,4,5,6,7,8,9,10};
int search = 9;
System.out.println(binarySearch(data, 0 , data.length-1, search));
}
public static int binarySearch(int arr[],int form, int to, int key){
if(form < to){
int mid = (form / 2) + (to / 2);//确定中间位置索引
if(arr[mid] == key){
return mid;
}else if(key > arr[mid]){
return binarySearch(arr, mid+1 , to , key);
}else if(key < arr[mid]){
return binarySearch(arr, form, mid-1, key);
}
}
return -1;
}
}
对象数组
之前所接触的都是基本数据类型的数据,那么对象也可以将其定义为数组,这样操作形式叫做对象数组。对象数组往往是引用数据类型为主的定义,例如类、接口,而且对象数组分为两种定义格式。
class Person{
private String name;
private int age;
public Person(String n, int a){
name = n;
age = a;
}
public void setName(String n){
name = n;
}
public void setAge(int a){
age = a;
}
public String getName(){
return name;
}
public int getAge(){
return age;
}
public String getInfo(){
return "name = " + name + ",age = " + age;
}
}
public class TestDemo7{
//对象数组
public static void main(String args[]){
Person per [] = new Person [3];//动态初始化
Person per1 [] = new Person [] {
new Person("张三",22),
new Person("张三1",22),
new Person("张三2",22)
};//静态初始化
per[0] = new Person("张三",22);
per[1] = new Person("李四",30);
per[2] = new Person("王五",13);
for(int i = 0;i < per.length ; i++){
System.out.println(per[i].getInfo());
}
System.out.println();
for(int i = 0;i < per.length ; i++){
System.out.println(per1[i].getInfo());
}
}
}
来源:https://blog.csdn.net/zsr6135/article/details/119193020
0
投稿
猜你喜欢
- IDEA打成jar包并在windows后台运行一、IDEA打成jar包1、File=>Project Structure=>Pr
- 建造者模式概述建造者模式(Builder Pattern)属于创建型模式。它是将一个复杂的构建与其表示相分离,使得同样的构建过程可以创建不同
- 一、封装一个工具类1、简易版package net.aexit.construct.acceptance.websky.utils;impo
- 一、基本概念(重要)Integer 是 int 的包装类,int 则是 java 的一种基本数据类型;Integer 变量必须实例化后才能使
- ErrorPageFilter的实际应用Spring框架错误页过滤器springboot提供了一个ErrorPageFilter,用来处理当
- 1.需求背景需要实现一个动态加载但不显示出来的视图,且该视图上有个动态生成的二维码,最后用其去生成一张快照(也就是图片)。(常见这种情况是来
- 我们都知道单精度浮点数(Single,float,Real)由32位0或1组成,它具体是如何来的。浮点数的32位N=1符号位(Sign)+8
- 工作以来,代码越写越多,程序也越来越臃肿,效率越来越低,对于我这样一个追求完美的程序员来说,这是绝对不被允许的,于是除了不断优化程序结构外,
- Java读取Properties文件的方法总结  
- 本文实例讲述了java实现将结果集封装到List中的方法。分享给大家供大家参考,具体如下:import java.sql.Connectio
- 其实这个表示有点不太对,应该是 Druid 动态切换数据源的方法,只是应用在了 springboot 框架中,准备代码准备了半天,之前在一次
- Spring如何使用 * 缓存解决循环依赖在没开始文章之前首先来了解一下什么是循环依赖@Componentpublic class A {@A
- 中文乱码问题真的是一个很棘手的问题,特别是从前台传到后台之后,都不知道问题出在哪里了。现在分享解决javaWEB中前后台中文乱码问题的3种方
- HashMap的原理 HashMap的数据结构为数组+链表,以key,value的形式存值,通过调用put与get方法来存值与取值。它内部维
- 在实际工作中,重试重发请求处理是一个非常常见的场景,比如:1、发送消息失败。2、调用远程服务失败。3、争抢锁失败。这些错误可能是因为网络波动
- 一、闭包的定义。有很多不同的人都对闭包过进行了定义,这里收集了一些。# 是引用了自由变量的函数。这个函数通常被定义在另一个外部函数中,并且引
- mybatis 查询返回Map<String,Object> 类型,平时没太注意怎么用,今天又遇到了总结记录一下,方便以后处理此
- 一 为什么要使用线程池对于操作系统而言,创建一个线程的代价是十分昂贵的, 需要给它分配内存、列入调度,同时在线程切换时要执行内存换页,清空
- 问题描述Spring Cache提供的@Cacheable注解不支持配置过期时间,还有缓存的自动刷新。我们可以通过配置CacheManneg
- Java try和catch的使用尽管由Java运行时系统提供的默认异常处理程序对于调试是很有用的,但通常你希望自己处理异常。这样做有两个好