IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Java基础学习第十一天(day11/day30数组中涉及的常见算法) -> 正文阅读

[数据结构与算法]Java基础学习第十一天(day11/day30数组中涉及的常见算法)

常见算法

在这里插入图片描述

1.求数组的最大值、最小值、平均值、总和

/*
    算法的考察:求数值型数组中元素的最大值、最小值、平均数、总和

    定义一个int型的一维数组,包含10个元素,分别赋一些随机整数
    然后求出所有元素的最大值,最小值,和值,平均值,并输出出来
    要求:所有随机数都是两位数

    [10,99]
    公式:(int)(Math.random()*(99-10+1)+10)
     */
    public static void main(String[] args) {
        int[] arr = new int[10];

        for (int i = 0; i < arr.length; i++) {
            arr[i] = (int) (Math.random() * (99 - 10 + 1) + 10);
        }

        //遍历
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + "\t");
        }
        System.out.println();

        //求数组元素的最大值
        int maxValue = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if (maxValue < arr[i]) {
                maxValue = arr[i];
            }
        }
        System.out.println("最大值为:" + maxValue);

        //求数组元素的最小值
        int minValue = arr[0];
        for (int i = 1; i < arr.length; i++) {
            if (minValue > arr[i]) {
                minValue = arr[i];
            }
        }
        System.out.println("最小值为:" + maxValue);

        //求数组元素的总和
        int sum=0;
        for(int i=0;i<arr.length;i++)
        {
            sum+=arr[i];
        }
        System.out.println("总和为:"+sum);

在这里插入图片描述

2.数组的反转

 //数组的反转
        String[] arr1=new String[]{"JJ","DD","MM","BB","GG","AA"};
        for(int i=0;i<arr.length/2;i++)
        {
            String temp=arr1[i];
            arr1[i]=arr1[arr1.length-i-1];
            arr1[arr1.length-i-1]=temp;
        }
        for(int i=0;i<arr1.length;i++)
        {
            System.out.print(arr1[i]+"\t");
        }
        System.out.println();

在这里插入图片描述

3.查找(线性查找、二分查找??)

  //线性查找
        String dest="BB";
        boolean isFlag=true;
        for(int j=0;j<arr.length;j++)
        {
            if(dest.equals(arr1[j]))
            {
                System.out.println("找到了指定的元素,位置为"+j);
                isFlag=false;
                break;
            }
        }
        if(isFlag)
        {
            System.out.println("很遗憾,没有找到哦!");
        }
        //二分查找:
        //前提:所要查找的数组必须有序
        System.out.println("----------------");
        int[] arr2=new int[]{-98,-34,2,34,54,66,79,105,210,333};

        int dest1=-34;
        int head=0;//初始的首索引
        int end=arr2.length-1;//初始的末索引
        boolean isFlag1=true;

        while(head<=end)
        {
            int middle=(head+end)/2;
            if (dest1 == arr2[middle]) {
                System.out.println("找到了指定的元素,位置为:"+middle);
                isFlag1=false;
                break;
            }
            else if(dest1<arr2[middle])
            {
                end=middle-1;
            }else//dest1>arr2[middle]
            {
                head=middle+1;
            }

        }
        if(isFlag1)
        {
            System.out.println("很遗憾,没有找到的啦!");
        }

在这里插入图片描述

排序算法

在这里插入图片描述
在这里插入图片描述

冒泡排序

在这里插入图片描述

//冒泡排序
        int[] arr3=new int[]{43,32,76,-98,0,64,33,-21,32,99};
        for(int i=0;i<arr3.length-1;i++)
        {
            for(int j=0;j<arr3.length-1-i;j++)
            {
                if(arr3[j]>arr3[j+1])
                {
                    int temp=arr3[j];
                    arr3[j]=arr3[j+1];
                    arr3[j+1]=temp;
                }
            }
        }
        for(int i=0;i<arr3.length;i++)
        {
            System.out.print(arr3[i]+" ");
        }

在这里插入图片描述

快速排序(思想)

在这里插入图片描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章           查看所有文章
加:2021-09-22 14:55:44  更:2021-09-22 14:58:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 23:12:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码