//
// main.c
// day08 #include <stdio.h> int main(int argc, const char * argv[]) { /*
int score = 99;
int score2 = 88;
int scores[88] = {1, 3, 5, 7};
元素类型 数组名称[元素个数];
*/
/*
// 0, 1, 2, 3
int scores[88] = {1, 3, 5, 7};
int scores2[88] = {2, 3, 5, 7};
int scores3[88] = {1, 9, 5, 7};
*/
/*
二维数组: 数组中的每一个元素又是一个数组, 那么这个数组就称之为二维数组
元素类型 数组名称[一维数组的个数][每个一维数组的元素个数];
元素类型 数组名称[行数][列数]; 元素类型: 说明二维数组中每个一维数组存储什么类型的数据
一维数组的个数: 说明二维数组有多少个元素
每个一维数组的元素个数 : 说明二维数组中每一个一维数组的元素个数
*/
int scoress[][] =
{
{, , , , }, // 0 // 每一个一维数组都是二维数组的一个元素
{, , , , },//
{, , , , } //
}; char names[][] =
{
// 0 1 2
{'l', 'n', 'j'}, //
{'x', 'm', 'g'} //
};
// 如何获取二维数组中的一维数组的元素的值
printf("%c\n", names[][]); // 如何遍历二维数组
// 思路: 1.取出二维数组的每一个元素(取出二维数组中的一维数组)
// 2.遍历一维数组 for (int i = ; i < ; i++) { // 0 , 1
// 1.取出一维数组
// names[i];
for (int j = ; j < ; j++) { // 0 , 1 , 2
printf("name[%i][%i] = %c\n", i, j, names[i][j]);
}
}
return ;
}
//
// main.c
// 二维数组注意点
//
// Created by xiaomage on 15/6/12.
// Copyright (c) 2015年 xiaomage. All rights reserved.
// #include <stdio.h> int main(int argc, const char * argv[]) {
// 1.二维数组的多种初始化方式
// 1.定义的同时初始化
int names[][] =
{
{'l', 'n', 'j'},
{'x', 'm', 'g'}
};
// 2.先定义再初始化
int names2[][];
names2[][] = 'l';
names2[][] = 'n';
names2[][] = 'j'; names2[][] = 'x';
names2[][] = 'm';
names2[][] = 'g'; // 3.完全初始化
int names3[][] =
{
{'l', 'n', 'j'},
{'x', 'm', 'g'}
}; // 4.不完全初始化
int names4[][] =
{
{'l', 'n'},
}; // 5.省略元素个数的两种写法
// 明确的告诉二维数组, 我们有2个一维数组
char names5[][] =
{
'l', 'n', 'j',
'x', 'm', 'g'
};
char names15[][] =
{
'l', 'n', 'j',
'x', 'm'
}; // 没有告诉二维数组我们有几个一维数组
// 如果在"定义的同时"进行初始化, 那么一位数组的个数可以省略 \
系统会自动根据每一个一维数组能够存放多少个元素, 自动根据初始化的值推断出二维数组中一共有多少个元素(多少个一维数组)
char names6[][] =
{
'l', 'n', 'j',
'x', 'm', 'g',
'n', 'b'
}; // 6.错误写法
// 注意点: 每个一维数组的元素个数不能省略
/*
int names7[2][] =
{
{'l', 'n', 'j'},
{'x', 'm', 'g'}
};
*/
/*
// 搞不清楚应该分配多大的存储空间, 以及搞不清楚应该把哪些数据赋值给第一个数组, 以及哪些数据赋值给第二个数组
int names7[2][] =
{
'l', 'n', 'j',
'x', 'm', 'g'
};
*/ return ;
}
//
// main.c
// 二维数组和函数
//
// Created by xiaomage on 15/6/12.
// Copyright (c) 2015年 xiaomage. All rights reserved.
// #include <stdio.h>
void change(int nums[]);
void change2(char names[][]);
void change3(char values[]);
void change4(char value); int main(int argc, const char * argv[]) { int nums[] = {, };
// 数组的名称就是数组的地址,保存的是数组第0个元素的地址,
// &nums == nums == &nums[0]
change(nums);
printf("nums[0] = %i\n", nums[]); char names[][] =
{
{'l', 'n', 'j'},
{'x', 'm', 'g'}
};
// &names == names == &names[0] == &names[0][0] , names就是数组的地址 , 都是一样的。
printf("&names = %p\n", &names);
printf("names = %p\n", names);
printf("&names[0] = %p\n", &names[]);
printf("&names[0][0] = %p\n", &names[][]); // 二维数组名称作为函数参数传递, 是传递的地址
change2(names);
//names[0] == 一维数组
change3(names[]); // names[0][0] == 一维数组的一个元素 == 值
change4(names[][]); printf("names[0][0] = %c\n", names[][]);
return ;
} // 基本数据类型
void change4(char value)
{
value = 'E';
printf("我执行了\n");
} // 以后只要看到函数的参数是一个数组, 那么就是地址传递
// 在函数中修改形参的值会影响到参数
void change3(char values[])
{
values[] = 'Q';
printf("我执行了\n");
} void change2(char values[][])
{
values[][] = 'w';
printf("我执行了\n");
} // 数组作为函数的参数传递, 修改形参的值会影响到实参
void change(int nums[])
{
nums[] = ;
printf("我执行了\n");
}

c15--二位数组的更多相关文章

  1. C++ 出现bug :二位数组的操作运算,求非对角线的元素的和

    编写一个通用程序,求出二位数组(行数和列数必须相等)的非对角线的元素之和,试建立类MATRIX完成上述功能 #include<iostream> using namespace std; ...

  2. PHP 之二位数组根据某个字段排序封装

    /** * @param $array * @param $keys * @param string $sort * @return array */ function arraySort($arra ...

  3. java中Arrays.sort()对二位数组进行排序

    int [][]a = new int [5][2]; //定义一个二维数组,其中所包含的一维数组具有两个元素 对于一个已定义的二位数组a经行如下规则排序,首先按照每一个对应的一维数组第一个元素进行升 ...

  4. php二位数组合并

    转自:http://www.cnblogs.com/losesea/archive/2013/06/14/3134900.html 题目:有以下2个二维数组 1$a=Array(0 => Arr ...

  5. 【shell】构造并遍历二位数组的一种用法

    参考shell数组的部分操作用法,实现了构造和遍历二维数组的一种方式,具体如下: #数组元素以空格分割 sites=("www.a.com www.b.com www.c.com www.d ...

  6. shell二位数组——终端字符下降动画

    猜想:Shell支持关联数组,可以利用关联数组模拟二维数组. [验证猜想] #!/bin/bash array[1,1]=1 array[2,1]=2 array[3,1]=3 for i in `s ...

  7. vector创建二位数组

    默认初始化vector vector<vevtor<int> > arr(row, vector<int>(col, 0)); //指定行大小为row,列为col, ...

  8. Rotate Image(二位数组顺时针旋转)

    问题描述: You are given an n x n 2D matrix representing an image. Rotate the image by 90 degrees (clockw ...

  9. php 按照二位数组中某个指定的字段进行排序

    /** * 按照二维数组中某个指定的某个字段进行排序 * @param $array 需要被排序的数组 * @param $flag 排序的标志 1,SORT_DESC 降序 2,SORT_ASC 升 ...

  10. 剑指offer:二位数组中的查找

    准备找实习期间,复习一下数据相关内容,刷刷题. 题目描述: 在一个二维数组中(每个一维数组的长度相同),每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样 ...

随机推荐

  1. CAGradientLayer 颜色渐变实现进度条

    #import <UIKit/UIKit.h> @interface TJGradientProgressView : UIView /** * 进度值 */ @property(nona ...

  2. C# 怎么把类文件如(XXX.cs)转为dll文件

    打开VS2012或2017 ,新建项目,选择  类库(.NET Framework),创建好一个项目 在建好的项目中添加需要转的类文件 然后将项目重新生成后,在项目的Debug下就可以找到对应的dll ...

  3. Mysql Event 自动分表

    create table TempComments Like dycomments; 上述 SQL语句创建的新表带有原表的所有属性,主键,索引等. 自动分表怎么做呢? 使用上述语句自动创建分表. 那么 ...

  4. Android studio 添加引用新建类库

    1.新建一个工程包 2.修改AndroidManifest.xml 将AndroidManifest.xml 修改为 <manifest xmlns:android="http://s ...

  5. sql server 存储过程(事务,带参数声明,数据库瘦身)

    CREATE PROCEDURE procedureName (@var1 as varchar(50),@var2 as varchar(50)) --建立未发临时表 AS begin tran - ...

  6. Percona Xtrabackup导出/导入单表

    默认情况下,InnoDB表不能通过直接复制表文件的方式在mysql服务器之间进行移植,即便使用了innodb_file_per_table选项.而使用Xtrabackup工具可以实现此种功能,不过,此 ...

  7. js 习题

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  8. springboot测试类

    Controller测试类 /** * Created by zhiqi.shao on 2017/5/12. */ @RunWith(SpringJUnit4ClassRunner.class) @ ...

  9. Java基础学习笔记: 多线程,线程池,同步锁(Lock,synchronized )(Thread类,ExecutorService ,Future类)(卖火车票案例)

    多线程介绍 学习多线程之前,我们先要了解几个关于多线程有关的概念.进程:进程指正在运行的程序.确切的来说,当一个程序进入内存运行,即变成一个进程,进程是处于运行过程中的程序,并且具有一定独立功能. 线 ...

  10. C语言编程-9_4 字符统计

    输入一个字符串(其长度不超过81),分别统计其中26个英文字母出现的次数(不区分大.小写字母),并按字母出现次数从高到低排序,若次数相同,按字母顺序排列.字母输出格式举例,例如:A-3,表示字母A出现 ...