#include <stdio.h> #include<stdlib.h> void main() { int a = 0, b = 0, i = 0, j = 0; printf("请输入数组行数\n"); scanf("%d", &a); printf("请输入数组列数\n"); scanf("%d", &b); int**array = (int**)malloc(sizeof(int*)*a); for (i = 0; i < b; i++) array[i] = malloc(sizeof(sizeof(int)*b)); for (i = 0; i < a; i++) { for (j = 0; j < b; j++) { printf("请输入第%d行%d列元素:\n", i + 1, j + 1); scanf("%d", &array[i][j]); } } printf("\n====输入完毕====\n"); int maxi,maxj=0,mini=0,minj, x, y,x_i,y_j; for (i = 0; i < a; i++) { maxi = 0; for (j = 0; j < b; j++) { if (maxi < array[i][j]) { maxi = array[i][j]; x = i; y = j; } } if (!mini || mini > maxi) { mini = maxi; x_i = x; y_j = y; } } printf("各行最大之最小为%d,下标%d %d\n", mini, x_i, y_j); for (i = 0; i < b; i++) { minj = INT_MAX; for (j = 0; j < a; j++) { if (minj >array[j][i]) { minj = array[j][i]; x = j; y = i; } } if (!maxj || maxj < minj) { maxj = minj; x_i = x; y_j = y; } } printf("各列最小之最大为%d,下标%d %d\n", maxj, x_i, y_j); }
时间: 2024-02-14 14:14:34 浏览: 15
这是一个 C 语言程序,主要功能是输入一个二维数组,然后通过比较各行最大值中的最小值和各列最小值中的最大值,输出它们的值以及它们在数组中的下标。具体实现过程为:首先通过动态分配内存的方式创建一个二维数组,然后通过嵌套的 for 循环输入数组中的元素。接着,通过两个 for 循环,分别找到各行最大值中的最小值和各列最小值中的最大值,并记录它们在数组中的下标。最后,输出各行最大之最小和它的下标,以及各列最小之最大和它的下标。
相关问题
#include<stdio.h>#include<stdlib.h>#include<string.h>
在C语言中,`#include<stdio.h>`、`#include<stdlib.h>`和`#include<string.h>`分别包含了输入/输出、内存管理以及字符串处理相关的库。这里给你演示如何使用这些头文件中的函数:
1. **输入/输出(stdio.h)**:
```c
#include<stdio.h>
int main() {
printf("Hello, World!\n"); // 使用printf输出字符串
scanf("%s", "Enter your name: "); // 使用scanf从用户那里读取输入
return 0;
}
```
2. **内存管理(stdlib.h)**:
```c
#include<stdlib.h>
int *createArray(int size) {
int *array = malloc(size * sizeof(int)); // 分配动态内存
return array;
}
void freeMemory(int *array, int size) {
free(array); // 释放已分配的内存
}
```
3. **字符串处理(string.h)**:
```c
#include<string.h>
char* copyString(const char* src) {
char* dest = (char*)malloc(strlen(src) + 1); // 动态分配内存复制字符串
strcpy(dest, src);
return dest;
}
```
注意,C语言的标准库函数可能需要链接到适当的库,如`-lstdc++` 或 `-lm`,具体取决于编译器设置。
Hanoi问题#include <stdio.h> #include <stdlib.h>
Hanoi问题是一个经典的递归问题,其目标是将一堆盘子从一个柱子移动到另一个柱子,每次只能移动一个盘子,并且大盘子不能放在小盘子上面。下面是一个C语言的Hanoi问题的递归实现:
```c
#include <stdio.h>
#include <stdlib.h>
void hanoi(int n, char A, char B, char C) {
if (n == 1) {
printf("Move disk 1 from %c to %c\n", A, C);
return;
}
hanoi(n-1, A, C, B);
printf("Move disk %d from %c to %c\n", n, A, C);
hanoi(n-1, B, A, C);
}
int main() {
int n;
printf("Enter the number of disks: ");
scanf("%d", &n);
hanoi(n, 'A', 'B', 'C');
return 0;
}
```
上述代码中,hanoi函数是递归函数,用于将n个盘子从A柱子移动到C柱子,B柱子作为辅助柱子。当n等于1时,直接将盘子从A柱子移动到C柱子。否则,先将n-1个盘子从A柱子移动到B柱子,再将第n个盘子从A柱子移动到C柱子,最后将n-1个盘子从B柱子移动到C柱子。在main函数中,首先输入盘子的数量n,然后调用hanoi函数。
相关推荐
![text/x-c](https://img-home.csdnimg.cn/images/20210720083646.png)
![image/gif](https://img-home.csdnimg.cn/images/20210720083352.png)
![application/msword](https://img-home.csdnimg.cn/images/20210720083327.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)