二维数组的定义:

数据类型 数组名称 [ 常量表达式1 ] [ 常量表达式2 ] = {.....}

int a[ 2 ][ 3 ] ={

  {4,5,6},

  {7,8,0},                 //或者{7} 后面不写8和9 ,系统会默认的帮你添加0就是这样:{7,0,0}

};

OR:

int b[ 3 ][ 2 ] ={3,87,43,66,82,11,34 };

OR:

int b[][ 2 ] ={3,87,43,66,82,11,34 };    //行数可以不写,但是列数不写或者2个都不写就不行.

// int a[][] = {1,2,3,4,5,6,7};  错误.

// int a[2][] = {1,2,3,4,5,6,7};错误.

字符串数组

char 数组名称 [字符串个数][每个字符串内存中允许存放的最大值] ={....}

char  str[ 3 ][ 20 ] ={"ipad","ipod","iphone"};

字符串数组本质上是一个二维数组,访问某个字符串使用数组名称[第一维下标].

每个字符串的长度不能超过第二维度的长度-1。

比如说:

char str2[ 3 ][ 20 ] ={"luoshuailuotingluomama","ipod","ipad"};

第二维度为20,20-1 =19,但是第一个字符串就超过了19.

char str2[ 3 ][ 20 ] ={"luoshuailuotingluomamadddddddssssssss","ipod","ipad"};     //不会报错,但是会警告.

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

printf("The end of Result :%s\n",str2[i]);

}

思考一个问题 :

创建一个字符串数组,对字符串 (英⽂)从小到大排序

  char  str[5][20] ={"ipad","ipod","iphone","main","luoshuai"};

  char temp[] ={0};

  int length =strlen(str);

  for(int i =0 ;i < length-1 ; i++ ){

    for(int j =0 ;j<length-i-1;j++){

      if(  strcmp( str[j] ,str[j+1] )  > 0 ){  

         strcopy(temp,str[j]);

         strcopy(str[j],str[j+1]);

         strcopy(str[j+1],temp);

      }

}

}

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

  printf("The end of Result : %s\n",str[i]);

}

选择排序法  

他的算法就是:将第一个与后面所有数字比较,如果找到比它还小的,两两数字交换.一轮下来最小值找到了.

 第二轮从第二个数字开始,与上面步骤相同.

int array[7] ={23,36,45,57,69,35,88};

for ( int i = 0; i < 7 ; i++) {

for (int j = i+1 ; j < 7; j++) {

if (array[i]  > array[j]) {

 int temp = array[i];

             array[i] =array[j];

array[j]  =temp;

}

}

}

优化版:可以省去很多不必要的循环:

for ( int i = 0;i < 6;i++) {     //外层循环 控制趟数,为个数减1. i= 0时候

int flag = 0 ;  //设置一个标记,如果两辆数字进行交换,我们就设置为1,

for (int j = i+1 ; j < 7; j++) {    //从第二个数,第三个..数分别与i=0数字比较.

if (array[i]  > array[j]) {     //i=0 分别与后面所有的比较一次,交换. j从1 开始 j<7  刚好内部循环6次.

  int temp = array[i];        //i=1的时候,j从下标2开始 j< 7 刚好循环5次

  array[i] =array[j];

  array[j]  =temp;

   flag = 1;

  }

}

//printf("循环的次数为:%d\n",(i+1));

if( !flag ){

  break;

 }

}

for (int i = 1; i< 7 ; i++) {    //输出数字.

printf("The end  of Result : %d\n",array[i]);

}

最新文章

  1. 速战速决 (3) - PHP: 函数基础, 函数参数, 函数返回值, 可变函数, 匿名函数, 闭包函数, 回调函数
  2. Install GDAL in OpenSUSE 12.3 Linux
  3. iOS开发——设备篇&amp;ios8文件路径
  4. Hadoop基于Protocol Buffer的RPC实现代码分析-Server端
  5. ArcEngine 9.3 学习笔记(六):图层符号化(COlorRamp,MarkerSymbol,LineSymbol,FillSymbol,TextSymbol,3DChartSymbol,使用ServerStyle符号库,FeatureRender,RasterRender)
  6. JVM典型配置
  7. 结对编程1-四则运算(基于GUI)
  8. 语句in
  9. KnockoutJS-快速入门
  10. robot framework---校验新增条数功能
  11. C# FTP操作报550错误
  12. vmware10.0.1安装redhat linux6.2每次启动vm崩溃问题解决!
  13. PHP安装-phpMyAdmin+Discuz
  14. SQL Server 2016 附加数据库提示创建文件失败如何解决
  15. [20180604]在内存修改数据(bbed).txt
  16. 在layui layer 弹出层中加载 layui table
  17. php算法,冒泡排序
  18. [Web 前端 ] 还在用浮动吗?CSS flex布局你了解多少?
  19. 前台登录和Token信息交互流程
  20. Hadoop NameNode 高可用 (High Availability) 实现解析[转]

热门文章

  1. 【2】python核心编程 第四章-python对象
  2. Java中操作时间比较好用的类
  3. abiword Related Pages
  4. &lt; IOS &gt; 文件中 某个类设置ARC,或者非ARC
  5. C语言随笔_fopen
  6. 剑指offer-面试题10:二进制中1的个数
  7. SVN强制填写日志
  8. 【C++基础之十四】函参的缺省
  9. HTML5 Canvas绘图系列之一:圆弧等基础图形的实现
  10. jar 查找多jar包中类的办法