c语言中用用数组排大小
时间: 2023-10-13 19:27:55 浏览: 51
下面是一个简单的示例代码来使用数组排序:
```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语言中用指针实现数组循环移动:
```c
#include <stdio.h>
#define N 6 // 数组大小
void move(int *arr, int n, int k) {
int *p = arr; // 定义指针p指向数组首地址
int temp[N]; // 定义一个临时数组
for (int i = 0; i < n; i++) {
*(temp + i) = *(p + i); // 将原数组中的元素复制到临时数组中
}
for (int i = 0; i < n; i++) {
*(p + (i + k) % n) = *(temp + i); // 将临时数组中的元素移动到原数组中
}
}
int main() {
int arr[N] = {1, 2, 3, 4, 5, 6};
int k = 2; // 移动的位数
move(arr, N, k);
for (int i = 0; i < N; i++) {
printf("%d ", *(arr + i)); // 输出移动后的数组
}
return 0;
}
```
在上述代码中,我们首先定义了一个指针p指向数组的首地址,然后使用一个临时数组temp将原数组中的元素复制到其中。接着,我们使用循环将临时数组中的元素移动到原数组中,移动的位置是`(i + k) % n`,其中i表示当前循环的下标,k表示移动的位数,n表示数组的大小。最后,我们在主函数中调用move函数,并输出移动后的数组。