求矩阵的鞍点 即列最小行最大

 1 #include<stdio.h>
 2 #include<stdlib.h> //malloc free  realloc
 3 
 4 /* 查找行最小 列最大的元素 找到之后直接输出 */
 5 void fun1(int arr[][4], int row)// 二维数组 传参需要传递行
 6 {
 7     int m, n;
 8 
 9     for (int i = 0; i < row; ++i)//有多少行 就找多少次
10     {
11         //查找一次的过程 查找这一行的最小值
12         m = 0;//列从0开始的
13         for (int j = 0; j < 4; ++j)
14         {
15             if (arr[i][j] < arr[i][m])//m表示这一行最小的元素 m返回这一行所在列数column
16             {
17                 m = j;
18             }
19         }
20         //arr[i][m] 是这一行最小的元素
21         //找这一列有没有比arr[i][m]更大的元素
22 
23         for (n = 0; n < row; ++n)//arr[0][m] arr[2][m]
24         {
25             if (arr[n][m]>arr[i][m]) //已知m的下标为最小值 即列最小 求行最大 遍历出行的值n 求所在行的最大值
26                 break;
27         }
28         if (n == row){
29             printf("所求的点是[%d,%d]\n", i, m);
30         }
31 
32     }
33 }
34 
35 
36 void test()//二维数组和数组指针
37 {
38     int arr[3][4] = {  // arr有三个元素  arr[0]  arr[1] arr[2]
39         9, 7, 4, 5,    //arr[0] 有四个元素  arr[0][0] arr[0][1] arr[0][2] arr[0][3]
40         7, 7, 3, 2,
41         1, 0, 2, 9
42     };
43     printf("arr[0]的大小%d\n", sizeof(arr[0])); //第一行的大小   
44     printf("arr[0][0]的大小%d\n", sizeof(arr[0][0]));
45     fun1(arr, 3);//表示数组有三行
46 }
47 int main()
48 {
49     test();
50     getchar();
51     return 0;
52 }

 

posted @ 2019-10-30 20:28  insist钢  阅读(509)  评论(0编辑  收藏  举报