二维数组

    定义方法1
            int[,] twodim=new int[3,3];
            twodim [0, 0] = 1;
            twodim [0, 1] = 2;
            twodim [0, 2] = 3;
            for (int i = 0; i < 3; i++) {
                for (int j = 0; j < 3; j++) {
                    Console.Write (twodim[i,j]+" ");
                }
                Console.WriteLine ();
            }
        

            int[,] arr = {
                {4,8,9,6,0},
                {7,4,22,11,4},
                {90,8,65,32,1},
                {12,5,2,8,0}
            };
            for (int i = 0; i < 4; i++) {
                for (int j = 0; j < 5; j++) {
                    Console.Write (arr[i,j]+" ");
                }
                Console.WriteLine ();
            }

            第二种方法
            锯齿数组
            int[][]twodim=new int[3][];
            twodim [0] = new int[]{ 1, 2, 3 };
            twodim [1] = new int[]{ 1, 2, 3, 4 };
            twodim [2] = new int[]{ 1, 2, 3, 4, 5 };
            for (int i = 0; i < twodim.Length; i++) {
                for (int j = 0; j < twodim[i].Length; j++) {
                    Console.Write(twodim[i] [j]+" ");
                }
                Console.WriteLine ();
            }

            总结二
            第一种声明格式,:int[,]遍历访问的时候采取arr[i,j]的方式进行访问
            第二种声明方式:int【】【】 此种写法的二维数组实际上是由多个一维数组构成
            列数,但是必须声明行数,访问方式是:arr[i][j];
            练习一:采用int【,】方式进行声明数组并初始换,遍历数组元素
            int [,]arr=new int[3,3];
            arr [0, 0] = 1;
            arr [0, 1] = 5;
            arr [0, 2] = 4;
            arr [1, 1] = 2;
            arr [2, 2] = 6;
            arr [1, 0] = 5;
            arr [1,2] = 9;
            arr [2,0 ] = 8;
            arr [2, 1] = 10;
        
            for (int i = 0; i < 3; i++) {
                for (int j = 0; j < 3; j++) {
                    Console.Write (arr[i,j]+" ");
                }
                Console.WriteLine ();
            }


            练习2:采用int[][]方式进行声明并初始化,遍历数组元素
            int[][]  arr=new int[3][];
            arr [0] = new int[]{3,4,5 }; 
            arr [1] = new int[]{ 7, 8, 9, 10 }; 
            arr [2] = new int[]{ 11, 12, 1, 3, 14,}; 
            for (int i = 0; i < 3; i++) {
                for (int j = 0; j < arr[i].Length; j++) {
                    Console.Write (arr[i][j]+" ");
                }
                Console.WriteLine ();
            }

练习3:有一个三行四列的二维数组,要求编程找出最大元素,并输出所在的行和列

            int[,] arr = {
                {4,8,9,6},
                {7,4,22,11},
                {90,8,65,32},
            };
            int max=0;
            int max0=0;
            int max1=0;
            for (int i = 0; i < 3; i++) {
                for (int j = 0; j <4 ; j++) {

                    if (arr [i,j] > max) {
                        max=arr [i,j];
                        max0 = i;
                        max1 = j;
                    }
                        
                    }
                }
        
            Console.Write ("最大值为: {0}坐标为:{1} {2}",max+" ",max0,max1);
            }


            Array.Reverse;
            Array.Sort;
            int[] arr={10,9,8,7,6};
            //Array.Reverse (arr);
            Array.Reverse(arr,0,2);
            foreach (var item in arr) {
                Console.WriteLine (item);
            }

            clone----会创建一个新的数组出来,他会在托管对开辟内存空间
            int [] intOrignArray=new int[4];
            intOrignArray [0] = 1;
            intOrignArray [1] = 2;
            intOrignArray [2] = 3;
            intOrignArray [3] = 4;

            演示clone方法
            int [] newArray=intOrignArray.Clone();  

            intOrignArray [0] = 100;
            //遍历newArray
            foreach (var item in newArray) {
                Console.WriteLine (item);
            }

            copy容器数组的长度必须大于或等于原数组的长度
            (浅拷贝与深拷贝的区别)
            int [] intOrignArray=new int[4];
            int[] newArray = { 1, 2, 3, 4 };
            newArray.CopyTo (intOrignArray, 0);

            newArray [0] = 100;
            foreach (var item in intOrignArray) {
                Console.WriteLine (item);
            }



            1.(**)从控制台先输入你一个整数n,表示之后会输入n个年龄.
            将结果按由大到小排序输出.例如:
            请输入n:
            3
            请输入3个年龄:
            28
            31
            19
            结果为:
            31,28,19
            Console.WriteLine ("请输入n:");
            int n = int.Parse (Console.ReadLine ());
            Console.WriteLine ("请输入{0}个年龄:",n);
            int []arr=new int[n];

            for (int i = 0; i <n ; i++) {
                arr [i] = int.Parse (Console.ReadLine ());
                }
            Array.Sort(arr);
            Array.Reverse (arr);
            foreach (var item in arr) {
                Console.Write ("{0},",item);
            }





            2.(**)求一个4阶数字矩阵(数值随机产生)对角线的和,如;
            1   2   3   4
            5   6   7   8
            9  10  11  12
            13 14  15  16
            输出: 69.
            int sum=0;
            int [,]arr=new int[4,4];
            for (int i = 0; i < 4; i++) {
                for (int j = 0; j <4; j++) { 
                    Thread.Sleep (10);
                    arr [i, j] =new Random ().Next (100);; 
                    if (i == j||i+j==3) {
                        sum += arr [i, j];
                    }
                }
            }

            for (int k = 0; k < 4; k++) {
                for (int l = 0; l < 4; l++) {
                    Console.Write (arr[k,l]+" ");
                }
                Console.WriteLine ();
            }
            Console.WriteLine ("对角线的和为:{0}",sum);

            3.(***)输入一个n,随机生成一个n*n的二维数组地图,数组元素值随机产生.完成如下操作.例如输入3,
            自动生成:
            1 2 3 
            4 5 6
            7 8 9
            int t=1; 
            int n=int.Parse(Console.ReadLine());
            int [,]arr=new int[n,n];

            for (int i = 0; i < n; i++) {
                for (int j = 0; j < n; j++) {
                    Thread.Sleep (10);
                    t=new Random ().Next (100);
                    arr [i, j]=t;
                }
            }
            for (int k = 0; k < n; k++) {
                for (int f = 0; f < n; f++) {
                    Console.Write (arr[k,f]+" ");
                }
                Console.WriteLine ();
            }

            1)求下三角元素的和.(上例为1+4+5+7+8+9=34)

            int[,] arr = { 
                {1,2,3},
                {4,5,6},
                {7,8,9}
            };
            int sum = 0;
            for (int i = 0; i < 3; i++) 
            {
                for (int j = 0; j < 3; j++) {
                    if (i >= j)
                    {
                        sum += arr [i, j];
                    }    
                    Console.Write (arr[i,j]+" ");
                }
                Console.WriteLine ();
            }
            Console.WriteLine ("三角元素的和为:{0}",sum);

            2)遍历二维数组,如果二维数组元素值为偶数,将元素更新为’*’,如果为奇数,将元素更新为’ #’.
            # * #
            * # *
            # * #

            int[,] arr = { 
                {1,2,3,},
                {4,5,6},
                {7,8,9}
            };
            for (int i = 0; i < 3; i++) {
                for (int j = 0; j < 3; j++) 
                {
                    if (arr [i, j] % 2 == 0) {

                        Console.Write ("* ");
                    }

                    else {
                        Console.Write ("# ");
                    }
                }
                Console.WriteLine ();
            }
                

            3)将上图看做一个游戏地图(#为二维坐标系0,0点),输入一个x,y值,将元素更改为’$’.
            例如:输入(0,0),输出
            # * #
            * # *
            $ * #

            int[,] arr = { 
                {1,2,3,}, 
                {4,5,6}, 
                {7,8,9} 
            };
            int a = int.Parse (Console.ReadLine ());
            int b = int.Parse (Console.ReadLine ());

            for (int i = 0; i < 3; i++) {
                for (int j = 0; j < 3; j++) 
                {

                    if (arr [i, j] % 2 == 0) { 

                        if (i == 3-b-1&&j==a) {
                            Console.Write ("$ ");
                        } else {
                            Console.Write ("* ");
                        }


                    }

                    else if(arr [i, j] % 2 != 0) {
                        if (i == 3-b-1&&j==a) {
                            Console.Write ("$ ");
                        } else {
                            Console.Write ("# ");
                        }
                    }

                }
                    
                Console.WriteLine ();
            }
//            5、(****)输入n(n < 10),代表矩阵n*n,输出蛇形矩阵。
//            例如:n = 3时,输出:
//                1 2 3
//                8 9 4
//                7 6 5
//                n = 4时,输出:
//                1  2  3  4
//                12 13 14 5
//                11 16 15 6
//                10 9  8  7
//

            int n =6;
            int temp = 1;
            int x = 0;//行上边
            int y =0;//行下边
            int a = 0;//列右边
            int b = 0;//列左边
            int[,] intArray = new int[n,n]; 

            for (int k = 1;  k < n*n; k ++) {
                if ( x <= n/2) { //一行
                    for (int i = b; i < n - a ; i++) {
                        intArray [x, i] = temp;
                        temp++;
                    }
                    x++;
                }

                if ( a <= n /2) {//一列
                    for (int i = x; i < n - y ; i++) {
                        intArray [i, n -1 -a] = temp;
                        temp++;
                    }
                    a++;
                }

                if ( y <= n / 2) {//二行
                    for (int i = n -1 - a ; i >= b; i--) {
                        intArray [n - 1 - y, i] = temp;
                        temp++;
                    }
                    y++;
                }

                if ( b <= n / 2) {//二列
                    for (int i = n - y -1 ; i >= x; i--) {
                        intArray [i, b] = temp;
                        temp++;
                    }
                    b++;
                }


            }

            for (int i = 0; i < n; i++) {
                for (int j = 0; j < n; j++) {
                    Console.Write (intArray [i,j]+ "\t");
                }
                Console.WriteLine ();
            }




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

推荐阅读更多精彩内容