java(四)创建静态数组

一、静态数组要分配内存空间

  • 语法:type[] ary = new type[number];

  1. int[] ary; 声明数组是什么类型;内存空间为5的数组;
  2. ary=new int[5];
  3. 用法:
public class XueArray {
    // 执行程序
    public static void main(String[] args) {
        int[] arrInt = new int[5]; // 数组长度为5
        byte[] arrByte = new byte[5];
        String[] arrString = new String[5];
        double[] arrDouble = new double[5];
        System.out.println("arrDouble[0] = " + arrDouble[0]); // 0.0
        System.out.println("arrInt[0] = " + arrInt[0]); // 0
        System.out.println("arrString[0] = " + arrString[0]); // null
        System.out.println("arrByte[0] = " + arrByte[0]); // 0
    }

}
  1. 第一种
int[] ary ={1,2,3,4} ;

// Arrays.toString(ary) 转化可打印的数组
System.out.println(Arrays.toString(ary)); // 输出 [1,2,3,4]

  1. 第二种
int[] ary = new int[]{1,2,3,4};
System.out.println(Arrays.toString(ary)); // 输出 [1,2,3,4]

三、创建一个二维数组

     int[][] erAry = new int[][]{{1, 2}, {3, 4}}; // [[1,2],[3,4]]

四、数组常见操作方法(Arrays)

  1. 控制台打印一维数组(Arrays.toString(ary))
int[] ary={1,2,3,4};
System.out.println("ary = " + Arrays.toString(ary));       
  1. 数组拷贝:(System.arraycopy(ary1,index,ary2,index,length))
  • System.arraycopy() 新数组和旧数组地址不一样
  • ary2=ary1 新数组和就数组地址一样
{
           int[] ary = {1, 2, 3, 4};
           int[] ary2 = new int[4];
           int[] ary3 = new int[4];
           ary3 = ary; // ary3根arr是同一个地址
           System.arraycopy(ary, 0, ary2, 0, 4);
           ary[0] = 10;
           System.out.println("ary2 = " + Arrays.toString(ary2)); // [1,2,3,4]
           System.out.println("ary3 = " + Arrays.toString(ary3)); // [10,2,3,4]
           System.out.println("ary = " + Arrays.toString(ary));   // [10,2,3,4]
       }
  1. 遍历数组
  • for循环
  • forEach
int[] ary = {1, 2, 3, 4, 5, 6};
 for (int i = 0; i < ary.length; i++) {
            System.out.println("item = " + ary[i]);
  }
for (int item : ary) {
            System.out.println("item = " + item);
 }        
  1. 替换元素(Arrays.fill())
  • 替换所有元素
    public static void main(String[] args) {
        int[] ary = {1, 2, 3, 4, 5, 6};
        Arrays.fill(ary,9);
        System.out.println("aryAry = " + Arrays.toString(ary)); // [9,9,9,9,9,9]
    }
  • 替换单独元素
    public static void main(String[] args) {
        int[] ary = {1, 2, 3, 4, 5, 6};
        Arrays.fill(ary,2,3,9);
        System.out.println("aryAry = " + Arrays.toString(ary)); // [1,2,9,4,5,6]
    }
  1. 数组排序(Arrays.sort(ary))
  • 字符串是按字典来排序;
  • 数字是按从小到大排序
  1. 复制数组 (Arrays.copyOf(ary,length))
  • 复制新的数组不是同一个地址
// 执行程序
    public static void main(String[] args) {
        int[] ary = {1, 2, 3, 4, 5, 6};
        int[] ary1 = Arrays.copyOf(ary, 3);
        ary[0]=100;
        System.out.println("ary1 = " +Arrays.toString(ary1) ); // [1,2,3]
    }

五、基本算法

  1. 冒泡算法
  • 原理:冒泡排序也是一种交换排序算法。冒泡排序的过程,是把数组元素中较小的看作是“较 轻”的,对它进行“上浮”操作。从底部开始,反复地对数组进行“上浮”操作 n 次,最后 得到有序数组。
  1. 快速排序
    https://www.zybuluo.com/xujun94/note/424850
  2. 选择性排序
    public void sort(int[] ary) {
        int index;
        for (int i = 1; i < ary.length; i++) {
            // 先拿出第一项出来
            index = 0;
            // 判断是否最大值
            for (int j = 1; j <= ary.length - i; j++) {
                // 如果匹配到最大值把index索引替换了
                if (ary[j] > ary[index]) {
                    index = j;
                }
            }
            int temp = ary[ary.length - i];    // 拿出来最后一项存起来
            ary[ary.length - i] = ary[index];  // 最后一项赋值最大的的值
            ary[index] = temp;                 // 最大项的位置给最后一项
        }
        System.out.println("ary = " + Arrays.toString(ary));
    }
  1. 数组反转
    思路:最后一个和第一个换位置,第二个和倒数第二个,所以循坏长度为总长度的一半
    public void reverse(int[] ary) {
        int len = ary.length;
        for (int i = 0; i < len / 2; i++) {
            int temp = ary[i];  // 第一项存起来
            ary[i] = ary[len - 1 - i];  // 第一项等于最后一项
            ary[len - 1 - i] = temp; // 最后一项等于第一项
        }
    }

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容

  • .1基础语言要素 1)标识符:给类、方法、变量起的名字 A.必须以字母或下划线或$符号开始,其余字符可以是字...
    晨星资源阅读 501评论 0 0
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,560评论 18 399
  • java笔记第一天 == 和 equals ==比较的比较的是两个变量的值是否相等,对于引用型变量表示的是两个变量...
    jmychou阅读 1,483评论 0 3
  • 我是日记星球177号星宝宝熙怡(yaya),我正在参加日记星球21天蜕变之旅,这是我的第82篇原创日记。 我是家庭...
    妙丫丫POI阅读 158评论 2 4
  • 昨日去面试,面试官问道JSONP,可惜我没能好好答出关键,直说没用过,竟不知自己在实际上有用过只是没有认识这个东西...
    Duobe阅读 263评论 0 0