c语言中用用数组排大小
时间: 2023-10-13 21:27:55 浏览: 79
下面是一个简单的示例代码来使用数组排序:
```c
#include <stdio.h>
int main() {
int arr[] = {5, 2, 9, 1, 8, 6, 3, 7, 4}; // 定义一个整型数组
int n = sizeof(arr) / sizeof(arr[0]); // 数组元素个数
int i, j, tmp;
// 冒泡排序算法
for (i = 0; i < n - 1; i++) {
for (j = 0; j < n - 1 - i; j++) {
if (arr[j] > arr[j + 1]) {
tmp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = tmp;
}
}
}
// 输出排序后的数组
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
该程序定义了一个整型数组 `arr`,然后使用冒泡排序算法对数组进行排序。排序后,使用循环输出排序后的数组元素。
相关问题
c语言中用二维数组做函数
在 C 语言中,我们可以使用二维数组来传递数据给函数。下面是一个简单的示例:
```c
#include <stdio.h>
void printArray(int arr[][3], int rows) {
int i, j;
for (i = 0; i < rows; i++) {
for (j = 0; j < 3; j++) {
printf("%d ", arr[i][j]);
}
printf("\n");
}
}
int main() {
int arr[2][3] = {{1, 2, 3}, {4, 5, 6}};
printArray(arr, 2);
return 0;
}
```
在上面的示例中,我们定义了一个二维数组 `arr`,并将其作为参数传递给 `printArray` 函数。`printArray` 函数接受一个二维数组和一个整数参数 `rows`,其中 `rows` 表示数组的行数。函数内部使用两个嵌套的循环来遍历二维数组中的所有元素,并打印它们的值。
在主函数中,我们初始化了一个二维数组 `arr`,并将其作为参数传递给 `printArray` 函数。函数将遍历并打印数组中的所有元素。
需要注意的是,当我们传递二维数组给函数时,需要指定数组的第二维大小,而第一维的大小可以省略。例如,上面的示例中,我们传递了一个 `int arr[][3]` 类型的数组参数,其中第一维的大小被省略了。
c语言中用代码表示数组中元素的个数
在C语言中,通常不直接存储数组元素的数量作为变量。因为数组的大小是静态确定的,并且编译器会知道它的长度。当你声明一个数组,如`int arr[5];`,编译器就知道这个数组有5个整数元素。
然而,如果你需要动态地获取数组的实际元素个数,一种常见的做法是在数组名前加上一个指向数组首元素的指针,并计算从该指针到数组结尾的距离(减去数组的第一个元素),这通常是通过将数组名与NULL值相加来实现,因为在大多数系统上NULL代表空地址。例如:
```c
#include <stdio.h>
#define ARRAY_LENGTH(arr) (sizeof(arr) / sizeof(arr[0]))
int main() {
int arr[] = {1, 2, 3, 4, 5};
size_t arraySize = ARRAY_LENGTH(arr);
printf("Array has %zu elements.\n", arraySize);
return 0;
}
```
这里,`ARRAY_LENGTH(arr)`是一个宏,用于计算数组的大小。请注意,这种方法仅适用于已知的数据类型,如果数组元素是结构体或联合体,需要考虑每个成员的大小。
阅读全文