C语言基础05
二维数组的定义:
数据类型 数组名称 [ 常量表达式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]);
}
C语言基础05的更多相关文章
- Java入门 - 语言基础 - 05.基本数据类型
原文地址:http://www.work100.net/training/java-basic-datatype.html 更多教程:光束云 - 免费课程 基本数据类型 序号 文内章节 视频 1 概述 ...
- 《MSSQL2008技术内幕:T-SQL语言基础》读书笔记(下)
索引: 一.SQL Server的体系结构 二.查询 三.表表达式 四.集合运算 五.透视.逆透视及分组 六.数据修改 七.事务和并发 八.可编程对象 五.透视.逆透视及分组 5.1 透视 所谓透视( ...
- javascript基础05
javascript基础05 1.变量的作用域 变量既可以是全局,也可以是局部的. 全局变量:可以在脚本中的任何位置被引用,一旦你在某个脚本里声明了全局变量,你就可以 在这个脚本的任何位置(包括函数内 ...
- 【GoLang】GO语言系列--002.GO语言基础
002.GO语言基础 1 参考资料 1.1 http://www.cnblogs.com/vimsk/archive/2012/11/03/2736179.html 1.2 https://githu ...
- C语言基础(转载自大海笔记)
# C语言基础2015年03月26日10:04:411. 语言排行榜C——java——objective-C2. 进制:进制:进位机制.用普通的话讲,应该为人为的定义一种度量来标识一样东西 ...
- 01_C语言基础
内容提要: 1. C语言概述2. 数据类型.运算符与表达式3. C语言程序结构 4. VC6.0使用练习 知识详解01:C语言的历史 1. C语言与其它语言比较 汇编语言: (1).可直接对硬件进行操 ...
- Go语言基础之time包
Go语言基础之time包 时间和日期是我们编程中经常会用到的,本文主要介绍了Go语言内置的time包的基本用法. Go语言中导入包 Go语言中使用import关键字导入包,包的名字使用双引号(”)包裹 ...
- D14——C语言基础学PYTHON
C语言基础学习PYTHON——基础学习D14 20180919内容纲要: 1.html认识 2.常用标签 3.京东html 4.小结 5.练习(简易淘宝html) 1.html初识(HyperText ...
- D05——C语言基础学PYTHON
C语言基础学习PYTHON——基础学习D05 20180815内容纲要: 1 模块 2 包 3 import的本质 4 内置模块详解 (1)time&datetime (2)datetime ...
随机推荐
- NAS4Free 配置BT下载
NAS4Free 9.3.0.2 开启BT下载功能 Services|BitTorrent 选中右上角的复选框 Peer port 是监听端口,用于接受外部连接,需要在路由器配置该端口到服务器,才能提 ...
- python的时间模块
python有两个重要的时间模块,分别是time和datetime 先看time模块 表示时间的几种方法: 1)时间元组:time.struct_time(tm_year=2016, tm_mon ...
- MVC中配置OutputCache的VaryByParam参数无效的问题
在项目使用OutputCacheAttribute是遇到了问题,当我想在配置文件web.config中配置OutputCache的VaryByParam时竟然不起作用,下面是相关代码: 文件FaceC ...
- 在Raspberry上使用小度WIFI
小度WIFI价格便宜量又足,我一真用它!做个广告先! 它使用联发科MT7601的芯片,质量不错,就是Raspberry下不能直接支持. 首先下载驱动 http://www.mediatek.com/_ ...
- Uubntu scrot 的简单使用
scrot 是一个使用 imlib2 库截取屏幕和保存图像的的工具. 1:安装 #apt-get install scrot 2:查看帮助 #scrot -help -v, --version显示版本 ...
- 源码编译安装 PHP5.5.0,解决curl_exec访问HTTPS返回502错误的问题(修改PATH路径)
最近碰到一个奇怪的问题, PHP使用 curl_exec 访问 HTTPS 网页时, 返回502错误, 访问HTTP网页时没有问题, 用 echo phpinfo() ; 查看, 支持op ...
- SQL Server 2008空间数据应用系列六:基于SQLCRL的空间数据可编程性
原文:SQL Server 2008空间数据应用系列六:基于SQLCRL的空间数据可编程性 友情提示,您阅读本篇博文的先决条件如下: 1.本文示例基于Microsoft SQL Server 2008 ...
- Generate Parentheses 解答
Question Given n pairs of parentheses, write a function to generate all combinations of well-formed ...
- No enclosing instance of type Outer is accessible. Must qualify the allocation with an enclosing instance of type Outer (e.g. x.new A() where x is an instance of Outer)
之前看内部类的时候没发现这个问题,今天写代码的时候遇到,写个最简单的例子: 下面这一段代码 红色的部分就是编译报错: No enclosing instance of type Outer is ac ...
- 如何将ASM中的数据文件复制到操作系统中
环境:Red Hat 5.7 + Oracle 10.2.0.5.0 Rac+ASM 如果你的Oracle数据库系统使用正使用ASM自动存储管理,你可曾想过要窥视一下ASM中的数据文件,ASM是个黑匣 ...