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
相关推荐
游是水里的游5 分钟前
【算法day19】回溯:分割与子集问题不想当程序猿_6 分钟前
【蓝桥杯每日一题】分糖果——DFShanbarger10 分钟前
mybatis框架——缓存,分页cdut_suye17 分钟前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试南城花随雪。25 分钟前
单片机:实现FFT快速傅里叶变换算法(附带源码)苹果醋329 分钟前
2020重新出发,MySql基础,MySql表数据操作小蜗牛慢慢爬行31 分钟前
如何在 Spring Boot 微服务中设置和管理多个数据库azhou的代码园34 分钟前
基于JAVA+SpringBoot+Vue的制造装备物联及生产管理ERP系统dundunmm40 分钟前
机器学习之scikit-learn(简称 sklearn)古希腊掌管学习的神41 分钟前
[机器学习]sklearn入门指南(1)