04.第七章:一维数组

1.数组

  • 一旦数组被创建 , 它的大小是固定的。
  • 不同于基本数据类型变量的声明 , 声明一个数组变量时并不在内存中给数组分配任何空间 。 它只是创建一个对数组的引用的存储位置。
    double [ ] myList =new double [ 10 ] :
    这条语句声明了数组变量 myList , 创建一个由 10 个 double 型元素构成的数组 , 并将该数组的引用賦值给 myList 。




2.数组复制


3.数组传参

4.数组的查找(线性查找,二分查找)

  • 线性查找


  • 二分查找(前提是数组必须按升序排好)
ublic class text3_线性查找二分查找 {
    //线性查找
    public static int linerSearch(int[] list, int key) {
        for (int i = 0; i < list.length; i++) {
            if (key == list[i]) return i;
        }
        return -1;
    }

    //二分查找
    public static int binarySearch(int[] list, int key) {
        int low = 0, high = list.length - 1;
        int mid;
        while (high >= low) {
            //找到中间那个数
            mid = (high + low) / 2;
            //如果关键值小于mid,说明在中间左边
            if (key < list[mid])
                high = mid - 1;
            else if (key == list[mid])
                return mid;
                //关键字大于mid,说明在中间右边
            else low = mid + 1;

        }
        return -1;

    }

    public static void main(String[] args) {
        int[] list = {1, 2, 3, 4, 5};
        //int key = linerSearch(list, 5);
        int key=binarySearch(list,5);
        System.out.print(key);
    }
}

5.数组的排序

  • 选择排序


    选择排序
public  static void  selectionSort(double[] list){
    //第一层循环用于控制找到最小元素后排列的位置(比如首先放到第一个位置,然后第二个位置)
    for(int i=0;i<list.length-1;i++){
        double min=list[i];
        int min_index=i;
        //为了找到一个最小的元素
        for(int j=i+1;j<list.length;j++)
        {
            if(list[j]<min){
                min=list[j];
                min_index=j;
            }
        }

        //找到了最小的元素min,及索引min_index,把它和前面list[i]互换
        if(min_index!=i) {
            list[min_index] = list[i];
            list[i] = min;
        }


    }
}
  • 冒泡排序
public class text5_冒泡排序 {

    public static void popsort(int []array){
        for(int i=0;i<array.length-1;i++){
            for(int j=i+1;j<array.length;j++){
                if(array[i]>array[j]){
                    int temp=array[i];
                    array[i]=array[j];
                    array[j]=temp;
                }

            }
        }
    }

    public static void main(String[] args){
        int []a={15,7,4,8,4};
        popsort(a);
        for(int i=0;i<a.length;i++){
            System.out.print(a[i]+" ");
        }
    }
}

6.Arrays类

  • 可以使用 sort 或者 parallelSort 方法对整个数组或部分数组进行排序
  • 可以采用二分査找法 ( binarySearch 方法 )在数组中査找关键字 。数组必须提前按升序排列好 。 如果数组中不存在关键字 ,方法返回 - ( 插入点下标 + 1 ) 。
  • 可以采用 equals 方法检测两个数组是否相等 。 如果它们的内容相同 , 那么这两个数组相等 。 在下面的代码中 , list1和 list 2 相等 , 而 list 2 和 list 3 不相等 。
  • 可以使用 fill 方法填充整个数组或部分数组 。
    例如 : 下列代码将 5 填充到 listl 中 ,将 8 填充到元素 list 2 [ 1 ] 到 list 2 [ 5 - 1 ] 中 。
  • 还可以使用 toString 方法来返回一个字符串 , 该字符串代表了数组中的所有元素 。


7.总结

  • 创建数组之后 , 它的大小就不能改变 , 可以使用 arrayRefVar . length 得到数组的大小 。 由于数组的下标总是从 0 开始 , 所以 , 最后一个下标总是 arrayRefVar . length - 1 。 如果试图引用数组界外的元索 , 就会发生越界错误 。
  • 当创建一个数组时 , 如果其中的元素的基本数据类型是数值型 , 那么賦默认值 0 。 字符类型的默认值为 ’ \u0000' ,布尔类型的默认值为 false 。
  • 将数组参数传递给方法时,实际上传递的是数组的引用;更准确地说,被调用的方法可以修改调用者的原始数组的元素 。
  • 如果数组是排好序的,对于査找数组中的一个元素而言,二分查找比线性查找更加髙效 。
  • 选择排序找到列表中最小的数字,并将其和第一个数字交换。然后在剩下的数字中找到最小的,和剩下列表的第一个元素交换 , 继续这个步骤 , 直到列表中只剩下一个数字 。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容

  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,473评论 0 3
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,243评论 0 16
  • 声明数组:elementType [] arrayRefvar;(元素类型[] 数组引用变量)例如:double ...
    五秋木阅读 162评论 0 0
  • 日化品公司看到这几张图片一定会有压力,过去男士用香皂或牙膏来刮胡子做准备,而如今“安娜莎”只需一张仅0.01...
    安娜莎护肤品阅读 239评论 0 0
  • 七月与安生 时间交错 生命轮回 你不是你 她不是她 也许我们过着自己脑子里应该活的生活,可什么是应该什么是不应该?...
    郝田甜阅读 300评论 0 0