package com.itheima;
import java.util.Random;
public class arrayoftentrain {
public static void main(String[] args) {
//求最值
int[] arr1 = new int[]{33,5,22,44,55};
int max = arr1[0];
for (int i = 1; i < arr1.length; i++) {
if(max < arr1[i])
max = arr1[i];
}
System.out.println(max);
//需求:生成10个1~100之间的数存入数组'
//1.求和 2.求平均数 3.统计有多少个数据比均值小
//一步一步来
//先创建一个数组 , 再用循环存入十个1~100的数字
int[] arr2 = new int[10];
Random r = new Random();
int sum = 0;
int count = 0;
for (int t = 0; t < arr2.length; t++) {
int randnumber = r.nextInt(100) + 1;
arr2[t] = randnumber; //存入
//可以边存入边求和
sum = sum + arr2[t];
}
System.out.println("总和为:" + sum);
//求均值
double avg = sum*1.0 / arr2.length;
System.out.println("均值为:" + avg);
//求个数
for (int k = 0; k < arr2.length; k++) {
if(arr2[k] < avg){
count++;
}
}
System.out.println("个数为:" + count);
//交换数组中的数据
int temp;
int[] arr4 = new int[]{1,2,3,4,5};
for (int i = 0 , j = arr4.length-1; i<j ; i++,j--) {
temp = arr4[i];
arr4[i] = arr4[j];
arr4[j] = temp;
}
//遍历
for (int q = 0; q < arr4.length; q++) {
System.out.print(arr4[q] + " "); //println 和 print不同 println就相当于在print后面加了个隔行符("\n")
}
System.out.println("\n");
//打乱数组数据
//思路:就是给索引进行操作 随机给索引一个值 让索引加上这个值 然后这两个索引的值进行交换
int[] arrs1 = new int[]{1,2,3,4,5};
Random sr = new Random();
int n=arrs1.length-1,m = 0;
int swap;
while(n >= 0){
int randnumber = sr.nextInt(n+1);//随机索引已就绪
swap = arrs1[m];
arrs1[m] = arrs1[randnumber + m];
arrs1[ randnumber + m ] = swap;
n--;
m++;
}
for (int i = 0; i < arrs1.length; i++) {
System.out.print(arrs1[i] + " ");
}
//我写的这个是比较复杂一点的,就是当原索引+1的时候,我让随机索引取值的范围-1
//当然也有简单的 ↓↓↓↓↓↓
// int[] arrs1 = new int[]{1,2,3,4,5};
// Random sr = new Random();
//
// int n =arrs1.length,m = 0;
// int swap;
// for (int i = 0; i < arrs1.length; i++) {
// int randomnumber = sr.nextInt(5);
// swap = arrs1[i];
// arrs1[i] = arrs1[randomnumber];
// arrs1[randomnumber] = swap;
// }
// for (int i = 0; i < arrs1.length; i++) {
// System.out.print(arrs1[i] + " ");
// }
}
}
java数组算法进阶
不会,就是不会!2023-09-19 8:06
相关推荐
BanyeBirth11 分钟前
C++动态规划——LIS(最长不下降子序列)小龙报11 分钟前
《算法通关指南---C++编程篇(3)》一叶飘零_sweeeet13 分钟前
深入 Spring 内核:解密 15 种设计模式的实战应用与底层实现凤山老林17 分钟前
排序算法:详解插入排序彦楠21 分钟前
IDEA实用快捷键豆沙沙包?28 分钟前
2025年--Lc197-077. 排序链表(链表,尾插法)--Java版m0_6515939134 分钟前
深入理解软件设计中的协议与规范:从理论到Java实践Knight_AL43 分钟前
Tomcat 类加载器隔离机制的实际应用FreeBuf_1 小时前
Spring两大漏洞可导致泄露敏感信息及安全防护绕过(CVE-2025-41253/41254)江太翁1 小时前
Kotlin 与 Java 互操作中常用注解