|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 moc 于 2018-7-29 12:09 编辑
数组排序的小程序
知识点:
1、数组初始化
2、函数的调用
3、数组做函数参数,会退化为指针
4、形参内出现char buf[10],int a[10] c/c++编译器也只会把他当做指针,也不会主动为其多分配内存空间 —>数据类型不一样
即形参定义得数据a[10]与程序中定义的a[10]的数据类型不一样****
- #include "stdio.h"
- #include "stdlib.h"
- #include "string.h"
- // 打印数组,函数写法
- void printfArray(int *a)
- {
- int i = 0;
- for (i = 0; i < 10; i++)
- {
- printf("%d ", a[i]);
- }
- }
- //扩展 指针参数 1、数组做函数参数,会退化为指针,数组名本生就是一指针
- void printfArray2(int *a, int num)
- {
- int i = 0;
- for (i = 0; i < num; i++)
- {
- printf("%d ", a[i]);
- }
- }
- //扩展 2、在形参内出现char buf[10],int a[10] c/c++编译器也只会把他当做指针,也不会主动为其多分配内存空间 —》数据类型不一样
- void printfArray3(int a[10])
- {
- int i = 0;
- int num1 = sizeof(a);
- int num2 = sizeof(*a);
- int num = sizeof(a) / sizeof(*a);
- printf("num1:%d, num2:%d, num:%d\n", num1, num2, num);
- for (i = 0; i < num; i++)
- {
- printf("%d ", a[i]);
- }
- }
- void main()
- {
- int i = 0, j = 0;
- int temp = 0; // Shift + del 组合删除一行
- int a[10] = { 1, 3, 44, 2, 3, 74, 5, 4, 6, 33 }; // 数组初始化
- int num1 = sizeof(a); // 思考:该处的sizeof(a)与printfArray3中的sizeof(a)为什么不一样, 提示:数据类型不一样
- printf("\n排序之前:%d", num1 );
- //for (i = 0; i < 10; i++)
- //{
- // printf("%d ", a[i]);
- //}
- printfArray3(a);
- printf("\n");
- // 排序算法,单位逐次比较法
- for (i = 0; i < 10; i++)
- {
- for (j = i + 1; j < 10; j++)
- {
- if (a[i] < a[j])
- {
- temp = a[i];
- a[i] = a[j];
- a[j] = temp;
- }
- }
- }
- printf("\n排序之后:");
- printf("\n排序之后:");
- printfArray3(a);
- printf("\n");
- *****
- }
复制代码
*****处为system("pause");
如果[code]中直接写上去小甲鱼网站竟然报405错误。 |
|