最大的两个数

题目截图:

 

思路:

  先对每列四个数按数值大小逆序排序,然后对最大的两个数按索引顺序排序即可。中间用到 qsort 函数,详细用法见另一篇博客

 

代码如下:

 1 /*
 2     最大的两个数 
 3 */
 4 
 5 #include <stdio.h>
 6 #include <string.h>
 7 #include <math.h>
 8 #include <stdlib.h>
 9 #include <time.h>
10 #include <stdbool.h>
11 
12 // 结点结构体 
13 typedef struct {
14     int data;                    // 数据 
15     int index;                    // 数组下标 
16 } node;
17 
18 // 按数据大小逆序排序 
19 int cmp1(const void* a, const void* b) {
20     node* c = (node*)a;
21     node* d = (node*)b;
22     return d->data - c->data;
23 }
24 
25 // 按原数组下标大小顺序排序 
26 int cmp2(const void* a, const void* b) {
27     node* c = (node*)a;
28     node* d = (node*)b;
29     return c->index - d->index;
30 }
31 
32 int main() {
33     int array[4][5];            // 存储矩阵 
34     int a[2][5];                // 存储每列最大的两个数 
35     node l[4];                    // 存储每列四个结点 
36     while(1) {
37         int i, j;
38         for(i=0; i<4; ++i) {    // 输入矩阵 
39             for(j=0; j<5; ++j) {
40                 if(scanf("%d", &array[i][j]) == EOF) {
41                     return 0;
42                 }
43             }
44         }
45         for(j=0; j<5; ++j) {    
46             for(i=0; i<4; ++i) {    // 初始化每列结点 
47                 l[i].data = array[i][j];
48                 l[i].index = i;
49             }
50             // 排序 
51             qsort(l, 4, sizeof(l[0]), cmp1);
52             qsort(l, 2, sizeof(l[0]), cmp2);
53             for(i=0; i<2; ++i) {    // 存储每列最大的两个数 
54                 a[i][j] = l[i].data;
55             }
56         }
57         for(i=0; i<2; ++i) {        // 按要求输出 
58             for(j=0; j<5; ++j) {
59                 printf("%d ", a[i][j]);
60             }
61             printf("\n");
62         }
63     }
64 
65     return 0;
66 }

 

转载于:https://www.cnblogs.com/coderJiebao/p/HustTest11.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 利用分治法求一个数据中最大个数和最小个数。 解释:该题要求在一个数据中找出最大个数和最小个数,可以利用分治法分别求出最大个数和最小个数。具体步骤是将数据分成部分,继续递归地分别求出左右部分的最大个数和最小个数,然后将结果合并得到全局的最大个数和最小个数。 ### 回答2: 分治法是一种重要的算法思想,其思想是将问题分解成若干个子问题,然后将子问题逐个求解并合并成原问题的解。在求一组数据中最大个数和最小个数的问题中,可以采用分治法,具体步骤如下: 1. 将原问题分解成个子问题,分别求出子问题中的最大和最小数。 2. 对于个子问题的最大数,取其中最大的一个。 3. 对于个子问题的最小数,取其中最小的一个。 4. 比较第2步和第3步得到的结果,即可得到原问题的最大个数和最小个数。 具体实现时,我们可以采用递归的方法对数据进行分治。在每一次递归时,把数据分成半,然后分别求出左半部分和右半部分的最大和最小数,并进行比较。 时间复杂度分析:假设有n个数,由于每次递归要处理一半的数据,因此递归树的高度为logn。对于每个子问题,在求解最大和最小数时需要比较三次,因此子问题的时间复杂度为O(3)。因此,整个算法的时间复杂度可以表示为O(3*logn)=O(logn)。所以,采用分治法求解一组数据中最大个数和最小个数的时间复杂度为O(logn)。 总之,分治法是一种高效且常用的算法思想,利用分治法求解一组数据中最大个数和最小个数的问题,可以大大提高算法的效率。 ### 回答3: 分治法是一种高效的算法,可用于解决各种问题,包括查找一组数据中最大个数和最小个数。分治法的基本思路是将一个大问题分成若干个相对简单的子问题,分别求解这些子问题,最后将结果合并得到最终解。 利用分治法求一组数据中最大个数和最小个数的步骤如下: 1. 将原始数据分成个子问题。 2. 对每个子问题进行递归求解,直到问题变得足够简单。 3. 合并个子问题的结果。 4. 返回最大个数和最小个数的值。 具体实现时,可以将数据分成个子问题,然后对每个子问题再次使用分治法,直到每个子问题只包含一个数。然后可以比较这个子问题的最大数和最小数,得到全局的最大数和最小数。最后,将全局的最大数和次大数以及最小数和次小数比较,得到最大个数和最小个数。 以下是具体实现的伪代码: ``` function find_max_min_numbers(array): if size(array) == 1: return (array[0], array[0]) else if size(array) == 2: return (max(array[0], array[1]), min(array[0], array[1])) mid = size(array) / 2 left_max, left_min = find_max_min_numbers(array[0:mid]) right_max, right_min = find_max_min_numbers(array[mid:size(array)]) max1, max2 = max(left_max, right_max), min(left_max, right_max) min1, min2 = min(left_min, right_min), max(left_min, right_min) return (max1, max2, min1, min2) ``` 该算法的时间复杂度为 O(nlogn),因为需要递归求解问题,在每个递归层级上需要进行 O(n) 次比较。但是,与其他 O(nlogn) 的算法相比,该算法具有更好的空间利用率,因为它使用了分治法的思想,即在任何时候,只需要存储当前问题的一部分,而不是整个数据集合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值