首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

C语言练习之实现对整型数组的冒泡排序

前言 实现一个对整形数组的冒泡排序 一、思路 这个程序用到两个循环: ①外循环控制排序的套数 ②内循环控制的是排序的过程 排序:判断相邻两个数,如果前一个数大于后一个数就将两个数的位置调换,直到每个数到达该到的位置...,整个数组都是由小到大排序即可 二、源代码以及运行截图 为了方便大家的交流和学习,我将程序源代码和运行截图放置在下方。...源代码: #define _CRT_SECURE_NO_WARNINGS #include //实现一个对整形数组的冒泡排序 //用到两个循环 //外循环控制排序的套数 //内循环控制的是排序的过程...0; i < sz; i++) { printf("%d ", arr[i]); } return 0; } 运行截图: ---- 总结   以上就是今天要讲的内容,本文简单的介绍了用C语言实现一个对整形数组的冒泡排序思路...本文的作者也只是一个正在学习C语言等编程知识的萌新,若这篇文章中有哪些不正确的内容,请在评论区向作者指出(也可以私信作者),欢迎大佬们指点,也欢迎其他正在学习C语言的萌新和作者进行交流。

40710

C语言整型数据类型

C语言中的整型数据类型int、short int 和 long int 名称 全称类型说明符 缩写类型说明符 位数 范围 整型 int int 16位 -32768至+32767 无符号整型 unsigned...int withd, height; int 类型的变量初始化方式: withd = 150; //前面已经声明,在此进行初始化 int height = 60; //直接在一个语句中进行声明和初始化 C语言整型常量有三种不同的表示形式...其它整数类型     int 是 C 语言的基本整数类型,可以满足我们处理一般数据的需求。C 语言还提供了四个可以修饰 int 的关键字:short、long、signed,以及 unsigned。...注意,C 定义字节的大小为 char 类型的大小。char 通常是 8 位(bit)的,当然也可以更大。这里我们假设 char 是 8 位的。    ...C99 标准 整型常量 十进制、八进制和十六进制的整型常量可加后缀以指示类型,如下表所示。

2.4K20

C语言进阶(二)--- 整型存放练习

整形存放练习题   接上篇博客中未完结的整型练习题   上一篇博客我们展示了百度2015年系统工程师笔试题(不了解的看上一期博客—C语言进阶之数据的存储),请简述大端字节序和小端字节序的概念,设计一个小程序来判断当前机器的字节序...我们了解了大小端字节序存储的概念及方法,而今天这篇博客,我们将继续练习整型数据在内存中如何进行存放。 练习(一) 1. //输出什么?...,b=%d,c=%d",a,b,c); return 0; }   请问最后的a,b,c打印的数字是多少?...unsigned char c = 255 a = -1 , b = -1,c = 255 ?...%d 打印的是有符号整型 %u 打印的是无符号的整形   这一题打印的是 a = 128时 无符号的整型   我们知道,在正数里,char类型取不到128,那我们就将128看做是127+1,那么我们可以根据上面的

53610

C语言进阶:整型数据的存储

三.整型提升 1.什么是整型提升: C整型算数运算总是至少以缺省整型类型的精度来进行的。...为了获得这个精度,表达式中的**字符和短整型操作数( char 属于整型家族 )**在使用之前被转换为普通整型,这种转换称为整型提升。...1.大端字节序:把数据的低位字节序的内容存放在高地址,高位字节序的内容存放在低地址; 2.小端字节序:把数据的低位字节序的内容存放在低地址,高位字节序的内容存放在高地址; 存放在地址中是以16进制形式存放的...} else printf("大端\n"); return 0; } 六.char 类型的存储问题 首先 char 类型到底是 signed char 还是 unsigned char ,C语言标准并没有规定...-1; printf("a=%d,b=%d,c=%d\n",a,b,c); return 0; } 正解:a=-1,b=-1,c=255 a 和 b 很好理解,问题就是c,我们利用上面的巧记口诀

13610

c语言 数组存放规则,C语言数组详解

下标表示了元素在数组中的顺序号。数组元素的一般形式为: 数组名[下标] 其中的下标只能为整型常量或整型表达式。如为小数时,C编译将自动取整。...由于数组a说明为 int类型,该类型占两个字节的内存空间,所以每个元素均占有两个 字节(图中每一格为一字节)。...二维数组元素的表示方法 二维数组的元素也称为双下标变量,其表示的形式为: 数组名[下标][下标] 其中下标应为整型常量或整型表达式。例如: a[3][4] 表示a数组三行四列的元素。...例如: char c[10]; 由于字符型和整型通用,也可以定义为int c[10]但这时每个数组元素占2个字节的内存单元。...{}写为: sratic char c[]=”C program”; 用字符串方式赋值比用字符逐个赋值要多占一个字节, 用于存放字符串结束标志’/0’。

6.1K30

C语言系列】C语言数组

二、数组的定义 格式: 类型 数组名[元素个数]; 举例:存储5个人的年龄 Int agrs[5]; //在内存中开辟4x5=20个字节的存储空间 可以在定义数组的同时对数组进行初始化: Int ages...Int count=5;int ages[count];//如果不进行初始化,则这种写法正确,编译器不会报错为其分配20个字节的存储空间,ages[0]=1;ages[1]=2;可以像这样对数组的元素进行赋值...Int x[]={1,2}; Char ca[5]={‘a’,‘A’,‘B’,‘C’,‘D’}; 数组名即代表数组的地址,数组的地址==数组名(ca)==数组的首元素的地址&ca[0] 在内存中,内存从大到小进行寻址...当你把一个数组当做参数来传递时,它会看做是一个指针,在该函数体内使用sizeof运算符来计算数组的长度,得出的数值永远为8,而非数组的实际长度,因为任何类型的指针都占8个字节的存储空间。...使用场合:五子棋,俄罗斯方块等, 假设: char Y[3][2]={ {‘A’,‘B’}, {‘C,‘D’}, {‘E,‘F’} }; 内存情况: ?

28.5K61

C语言数组

C 语言支持数组数据结构,它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据,但它往往被认为是一系列相同类型的变量。...声明数组C 中要声明一个数组,需要指定元素的类型和元素的数量,如下所示: type arrayName [ arraySize ]; 这叫做一维数组。...arraySize 必须是一个大于零的整数常量,type 可以是任意有效的 C 数据类型。...初始化数组C 中,您可以逐个初始化数组,也可以使用一个初始化语句,如下所示: double balance[5] = {1000.0, 2.0, 3.4, 7.0, 50.0}; 大括号 { }...访问数组元素 数组元素可以通过数组名称加索引进行访问。元素的索引是放在方括号内,跟在数组名称的后边。

5K10

C语言数组

+ 1); printf("%p\n", &a); printf("%p\n", &a + 1); } 结果: 0028FF28 0028FF34 0028FF28 0028FF2C...可以把数组名理解一个指针,其值就是低一维首元素的地址。 我们看到+1的步长,a+1中间隔了12个字节,也就是3个int相当于第一维的长度。...而&a+1的步长是整个数组的长度 指针数组 int *a[3] 。为什么这里是指针数组。[]的优先级高于* ,所以这是一个数组,而*修饰数组,所以是指针数组数组的元素是整型的指针。...示例: typedef int arr[3]; int main() { arr b = {1, 2, 3}; int (*a)[3] = &b; arr *c = a;...我们自定义了一个数据类型,为数组数据类型。起数据类型为三个整型元素的数组。 定义数组指针也有两种方式,一个是使用我们上面自定义的数组数据类型,一个是直接定义。

4.9K30

C语言——数组

→   int arr [3] ={1,2,3}  数组如果初始化了,可以不规定大小,数组会根据初始化的大小来确定大小 c数组的类型 数组里的元素有分类型,数组也是有类型的,而数组算是一种自定义类型。...a,数组下标 C语言中,数组的下标是从0开始的,如果有n个元素,则第一个元素的下标为0,最后一个元素的下标为n-1 ,下面举例: 对于:            int arr [5] = {1,2,3,4,5...}; 数组元素:           1   2   3  4   5  对应下标:           0   1   2   3  4   C语言中 [ ] 是“下标引用操作符” ,...,我们可以得出,数组在内存储存的特点是: 1,数组随下标的增长,地址由小变大 2,并且每两个相邻的元素之间相差4(即一个整形的大小:4个字节) 三,二维数组 (1)了解二维数组 如果我们把一维数组当做数组的元素...储存 用同样的打印方法,我们来观察二维地址的特点: 不难发现,和一维数组所得出的结论应该一致: 1,数组随下标的增长,地址由小变大 2,并且每两个相邻的元素之间相差4(即一个整形的大小:4个字节) 四,

11310

c语言_数组

数组 1、数组的定义和使用 格式: 数据类型 数组名[元素个数] 元素个数,代表该数组有多少个相同数据类型的变量 下标 用来表示数组中的某一个元素 例如 int arr[10]; arr[1]代表数组的第二个元素...数组下标是从0开始的 到数组元素个数-1 数组下标越界:超出了数组元素个数的下标,如果操作越界数据会出现程序错误 1、乱码结果 2、报错 求出数组元素个数: int (size_t) unsigned...int 个数 = sizeof(数组名)/sizeof(数组元素 | 数组数据类型) 求出数组地址: printf("%p\n",数组名) printf("%p\n",数组元素) 数组元素+1 (sizeof...)/sizeof(数组名[0]); 求列数:sizeof(数组名[0])/sizeoef(数组名[0][0]) 二维数组首地址表示方式: printf("%p\n",数组名); 练习:10名学生 三门成绩...’\0’】之前的所有字符 在ASCII中就是数字0 ​ printf("%s", arr); ​ //for (int i = 0; i < 10; i++) ​ //{ ​ // printf("%c"

4.5K20

C语言-数组

数组介绍 C语言数组是一个同类型数据的集合,主要用来存储一堆同类型的数据。 程序里怎么区分是数组?[ ] 这个括号是数组专用的符号. 定义数组、 访问数组数据都会用到。...数组的定义语法: int data[10]; [常量-整数-数据数量]; 定义一个int类型的数组数组的名称是data,长度是10,所占空间大小:4*10 字节。...数组在定义之后就无法更改大小。 4. 数组的空间是连续的—内存。 5. 数组的名称就是数组空间的首地址。 6. 数组初始化时,如果没有赋值,那么数组空间里的数据是未知的---局部变量。 7....数组定义语法与注意事项 1. 数组的名称是数组元素的首地址。(数组的名字就是地址) 2. 数组只能在初始化的时候进行整体赋值。比如: int a[100]={10,20,30}; 3....数组定义的时候(C89), 数组的下标里的大小只能填常量。

4K10

C语言_函数【

toascii(int c)   返回c相应的ASCII int    tolower(int ch)  若ch是大写字母('A'-'Z')返回相应的小写字母('a'-'z') int   _tolower...void *destin,void *source,unsigned n) void *memset(void *s,char ch,unsigned n) 这些函数,mem…系列的所有成员均操作存贮数组....在所有这些函数中,数组是n字节长. memcpy从source复制一个n字节的块到destin.如果源块和目标块重叠,则选择复制方向, 以例正确地复制覆盖的字节. memmove与memcpy相同....memset将s的所有字节置于字节ch中.s数组的长度由n给出. memcmp比较正好是n字节长的两个字符串s1和s2.些函数按无符号字符比较字节,因此, memcmp("0xFF","\x7F",1)...(2)n个字节已复制到destin. memchr对字符ch检索s数组的前n个字节.

4.7K30

C语言数组——字符数组

字符数组 字符数组顾名思义就是数组的元素类型为字符型的数组。特殊之处在于它是数组元素为字符的数组。其定义的一般形式和注意事项与之前讲解的一般数组类似,只是其中的类型说明符是char。...当然,并不是说类型说明符只能是char,也可以是long、int等,但是由于char型只占用一个字节的大小,使用long型和int型来定义字符数组会造成资源的浪费,因此一般选择使用char型来定义字符数组...}; for (i = 0; i < SIZE; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 运行结果为“Hello...='\0'; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 这时的输出结果中就不含有任何空字符了,因为巧妙地使用了字符数组中的...= '\0'; i++) { printf("%c", arr[i]); } return 0; } 运行结果: 在对一维字符数组进行定义和初始化的过程中,可以不指定其长度。

7.3K20

c语言输出整型量格式符,C语言输出格式(详细)

C语言格式化输出 一、printf()函数 printf()函数是格式化输出函数,一般用于向标准输出设备按规定格式输出信息。在编写程序时经常会用到此函数。...比如说%3d 表示输出3位整型数,不够3位右对齐。...(2)%ld: 输出长整型数据。比如下面的就不能用%d。...(2)浮点数表示字符或整型量的输出格式,如%6.9s 和%6.9d 如果用浮点数表示字符或整型量的输出格式,小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。...: 输出长整型数据 printf(“输出长整型数据:d=%ld\n”,d); printf(“指定输出的宽度输出长整型数据:d=%9ld\n”,d); //%-md:可以控制输出左对齐,即在”%”和字母之间加入一个

4K20

C语言数组——字符数组

C语言目录 C/C++学习资源(百度云盘链接) 计算机二级资料(过级专用) C语言学习路线(从入门到实战) 编写C语言程序的7个步骤和编程机制 C语言基础-第一个C程序 C语言基础-简单程序分析...VS2019编写简单的C程序示例 简单示例,VS2019调试C语言程序 C语言基础-基本算法 C语言基础-数据类型 C语言中的输入输出函数 C语言流程控制语句 C语言数组——一维数组...C语言数组——二维数组 前面两篇文章分别介绍了一维数组和二维数组,今天我们一起看看字符数组 字符数组 字符数组顾名思义就是数组的元素类型为字符型的数组。...当然,并不是说类型说明符只能是char,也可以是long、int等,但是由于char型只占用一个字节的大小,使用long型和int型来定义字符数组会造成资源的浪费,因此一般选择使用char型来定义字符数组...如果您觉得本篇文章对您有帮助,请转发给更多的人 【C语言中文社区】是一个C语言视频教程、学习笔记、电子书、计算机二级资料等专注于C语言编程学习者的干货知识分享平台,精选深度文章,分享优秀干货类、技能类的学习资源

6.1K40
领券