《Java从入门到放弃》JavaSE入门篇:数组

数组,就是一组数!!!

之前我们学习的变量只能保存一个数据,如果一个部门有50个员工的姓名要保存,怎么办?如果定义50个变量··················

String name1;

String name2;

......

......

String name49;

String name50;

,这画面太美,我不敢看...

就算你保存下来了,现在我要找一个叫“罗大锤”的员工,那代码怎么写呢?

    if(name1.equals("罗大锤")){

    }

    if(name2.equals("罗大锤")){

    }

    ......

    if(name49.equals("罗大锤")){

    }

    if(name50.equals("罗大锤")){

    }

,这代码更美,看得要咽口水...

这时,数组出现了!!!他身披金甲圣衣,脚踏七彩祥云.....,好吧,不废话了,直接上代码:

    public static void main(String[] args) {
        //定义保存50个员工姓名的
        String[] names = new String[50];
        //2.赋值
        names[0] = "张小萌"; 
        names[10] = "李二爷";
        names[20] = "罗大锤";
        //3.查找是否有员工叫罗大锤
        for (int i = 0; i < names.length; i++) {
            if(names[i]!=null && names[i].equals("罗大锤")){
                System.out.println("找到罗大锤了,他的编号是"+i);
                break;
            }
        }
    }

注意:

  1. 数组的好处是解决了相同类型变量的存储问题。
  2. 定义数组与定义普通变量相比,多了一对[],并且数组的默认值,数值类型的值为0,引用类型的值为null。
  3. 后面new String[50],表示数组可以存储数据的个数,如果在使用时超过了范围则报错。
  4. 赋值是names[0] = "xxx";,这儿的[0]表示下标(也叫偏移量)。因为数组在内存是一块连续的内存空间,所以它是这样滴

,names默认指向第一个数据,所以它偏移0个位置就是第一个数据,偏移1个位置就是第二个数据。所以最后一个数据的下标是——49!!!

  1. 数组一般配合循环使用。

OK,数组就这样了,多简单个东西啊!!!当然,他还有很多细节的语法,比如定义时这样写才是正确的:

String[] names = new String[50];
String[] names2 = {"aaaa","bbb","ccc"};
String[] names3 = new String[]{"aaaa","bbb","ccc"};

最后最后最后,数组的几个常用操作:

一、数组元素的遍历

    public static void main(String[] args) {
        //定义数组并赋初值
        int[] nums = {234,64,13,2,7,6,4,334,34};
        //遍历数组,length表示数组的元素个数
        for (int i = 0; i < nums.length; i++) {
            System.out.println("第"+(i+1)+"个元素的值为:"+nums[i]);
        }
    }

二、数组的排序

    public static void main(String[] args) {
        //定义数组并赋初值
        int[] nums = {234,64,13,2,7,6,4,334,34};
        //遍历数组
        for (int i = 0; i < nums.length; i++) {
            System.out.println("第"+(i+1)+"个元素的值为:"+nums[i]);
        }
        //数组排序
        Arrays.sort(nums);
        System.out.println("排序后的结果:");
        //遍历数组
        for (int i = 0; i < nums.length; i++) {
            System.out.println("第"+(i+1)+"个元素的值为:"+nums[i]);
        }
    }

结果:

如果要降序排列的话,我们还可以自己写代码:

    public static void main(String[] args) {
        //定义数组并赋初值
        int[] nums = {234,64,13,2,7,6,4,334,34};
        //遍历数组
        for (int i = 0; i < nums.length; i++) {
            System.out.println("第"+(i+1)+"个元素的值为:"+nums[i]);
        }
        //数组排序
        for (int i = 0; i < nums.length; i++) {
            for (int j = i+1; j < nums.length; j++) {
                if(nums[i]<nums[j]){
                    int tmp = nums[i];
                    nums[i] = nums[j];
                    nums[j] = tmp;
                }
            }
        }
        System.out.println("排序后的结果:");
        //遍历数组
        for (int i = 0; i < nums.length; i++) {
            System.out.println("第"+(i+1)+"个元素的值为:"+nums[i]);
        }
    }

三、二维数组

前面所学的都是一维数组,比如保存一个部门的50名员工,就可以使用一维数组,如果公司有4个部门,人数最多的部门有50名员工,那需要这样定义数组:

String[][] names = new String[4][50];

并且现在要使用嵌套的循环来进行遍历了:

//外层遍历部门数
for (int i = 0; i < names.length; i++) {
    //里层遍历每个部门的员工数
    for (int j = 0; j < names[i].length; j++) {
        System.out.println("这是部门"+(i+1)+"中的员工第"+(j+1)+"个员工");
    }
}

到这儿,数组是真滴结束了,老规矩,布置几个练习吧:

  1. 输入一个字符串,分别统计出其中英文大写字母、小写字母、数字以及其它字符的个数
  2. 输入10个员工的薪水,求平均薪水和总薪水分别是多少,并统计5000以下有多少人,5000及以上的有多少人
  3. 已有一个已排好序的数组{23,34,55,87,108,210},现在输入一个数,要求按原来排序的规律将它插入到数组中
  4. 随机输入5个整数存入一个数组,然后按从小到大的顺序排序,并输出

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏深度学习思考者

Python学习(三) 八大排序算法的实现(上)

   本文Python实现了直接插入排序、基数排序、冒泡排序、快速排序、直接选择排序、堆排序、归并排序、希尔排序。    上篇来介绍前四种排序方式:  ...

1888
来自专栏较真的前端

前端面试题“七连击”(一)

1867
来自专栏编程

八大排序算法的 Python 实现!

今天CoCo酱给大家介绍一下关于八大排序算法的Python实现,对八大排序算法进行详细描述和代码实现,下面我们一起来看一下吧。 1、插入排序 描述: 插入排序的...

2147
来自专栏来自地球男人的部落格

[LeetCode] 152. Maximum Product Subarray

【原题】 Find the contiguous subarray within an array (containing at least one nu...

2055
来自专栏Linux Python 加油站

Python基础之set应用详解

一个{ }里面放一些元素就构成了一个集合,set里面可以是多种数据类型(但不能是列表,集合,字典,可以是元组)

1705
来自专栏人工智能LeadAI

为什么算法容易忘记之插入排序

在学习常用的排序算法时,常有这样的感觉,一看就懂,过眼就忘。原因在于没有将排序的基本思想与代码中各个循环控制变量的意义联系起来进行理解记忆。 插入排序 首先,我...

3495
来自专栏python学习之旅

算法笔记(六):计数排序和基数排序

        这里我是按自己的理解去实现的,时间复杂度和空间复杂度和算法导论上的可能不一样,感兴趣的话参考下就行,感觉最重要的还是算法思想。根据算法性能去实现...

1432
来自专栏小詹同学

LeetCode 系列——双指针问题 。

关于 LeetCode 系列有段时间没有逐题更新了 ,还是想到一题一题的刷有些凌乱 。如前段时间的推文所说 ,准备系统的讲讲数据结构相关知识点 。

1202
来自专栏云霄雨霁

排序----归并排序

1460
来自专栏ACM算法日常

字符串展开(递归)- HDU 1274

常用纱线的品种一般不会超过25种,分别可以用小写字母表示不同的纱线,例如:abc表示三根纱线的排列;重复可以用数字和括号表示,例如:2(abc)表示abcabc...

762

扫码关注云+社区