java数组算法进阶

复制代码
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] + " ");
//        }
    }
}
相关推荐
CodeAmaz4 分钟前
Spring编程式事务详解
java·数据库·spring
没有bug.的程序员6 分钟前
微服务基础设施清单:必须、应该、可以、无需的四级分类指南
java·jvm·微服务·云原生·容器·架构
武子康9 分钟前
Java-204 RabbitMQ Connection/Channel 工作流程:AMQP 发布消费、抓包帧结构与常见坑
java·分布式·消息队列·rabbitmq·ruby·java-activemq
郑州光合科技余经理10 分钟前
海外国际版同城服务系统开发:PHP技术栈
java·大数据·开发语言·前端·人工智能·架构·php
跨境卫士苏苏11 分钟前
突围新品广告泥潭:亚马逊广告底层逻辑大重构
大数据·人工智能·算法·重构·亚马逊·防关联
appearappear20 分钟前
Mac 上重新安装了Cursor 2.2.30,重新配置 springboot 过程记录
java·spring boot·后端
CryptoRzz29 分钟前
日本股票 API 对接实战指南(实时行情与 IPO 专题)
java·开发语言·python·区块链·maven
程序员水自流31 分钟前
MySQL数据库自带系统数据库功能介绍
java·数据库·mysql·oracle
旧梦吟35 分钟前
脚本网页 三人四字棋
前端·数据库·算法·css3·html5
谷哥的小弟36 分钟前
Spring Framework源码解析——RequestContext
java·后端·spring·框架·源码