1.求数组中的最大值时,定义最大变量max来存储最大值,max初始化的值一定是数组中的值。
//求数组中的最大值
public class Demo01 {
public static void main(String[] args){
int[] arr = {14,87,36,78,98};
int max = arr[0];
for (int i = 1; i < arr.length; i++) {
if(arr[i] > max){
max = arr[i];
}
}
System.out.println("数组中的最大值为:"+max);
}
}
2.遍历数组求和
需求:生成10个1~150之间的随机数存入数组。
(1)求所有数据的和
(2)求所有数据的平均数
(3)统计有多少个数据比平均值小
import java.util.Random;
public class Demo02 {
public static void main(String[] args){
int[] arr = new int[10];
Random r = new Random();
for (int i = 0; i < arr.length; i++) {
arr[i] = r.nextInt(150)+1;
}
System.out.println("随机生成的10个数为:");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
//求数组中所有数的和
int sum = 0;
for (int i = 0; i < arr.length; i++) {
sum = sum + arr[i];
}
System.out.println("\n"+"数组中所有数组中的和为:"+sum);
//求数组中所有数据的平均数
int avg = sum / 10;
System.out.println("数组中所有数据的平均数为:"+avg);
//求数组中比平均数小的个数
int count = 0;
for (int i = 0; i < arr.length; i++) {
if(arr[i] < avg){
count++;
}
}
System.out.println("数组中比平均数小的个数为:"+count);
}
}
运行结果:
3.定义一个数组,随机生成1~100中的5个数存入数组中,交换首首尾索引对应的元素。
import java.util.Random;
public class Demo03 {
public static void main(String[] args){
int[] arr = new int[5];
Random r = new Random();
for (int i = 0; i < arr.length; i++) {
arr[i] = r.nextInt(100)+1;
}
System.out.println("交换前:");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
for(int i = 0,j = arr.length -1;i < j;i++,j--){
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
System.out.println("\n"+"交换后:");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
}
运行结果:
4.随机打乱数组中的数据
import java.util.Random;
public class Demo05 {
public static void main(String[] args){
int[] arr = {1,2,3,4,5,6,7,8,8,10};
System.out.println("数组打乱前:");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
Random r = new Random();
for (int i = 0; i < arr.length; i++) {
//生成一个随机索引
int index = r.nextInt(arr.length);
int temp = arr[i];
//拿着随机索引指向的元素与i索引指向的元素进行交换
arr[i] = arr[index];
arr[index] = temp;
}
System.out.println("\n" + "数组打乱后:");
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i] + " ");
}
}
}
运行结果:
java的内存分配:
栈:方法运行时使用的内存,比如main方法运行,进入方法栈中执行
堆:new来创建的,都存储在堆内存
当两个数组指向同一个小空间时,其中一个数组堆小空间中的值发生了改变,那么其他数组再次访问的时候都是修改之后的结果了。