zoukankan      html  css  js  c++  java
  • 分治法求集合最大元

    题目:输入n  然后输入n个整数,用分治法求这n个数中的最大元;

    思路:把这列数分成两半,递归下去,到只剩一个数时停止,返回这个数,如果不是一个数则返回分成的两段数最大值的较大者;

    实验提示:在规模为n的数据元素集合中找出最大元。当n=2时,一次比较就可以找出两个数据元素的最大元和最小元。当n>2时,可以把n个数据元素分为大致相等的两半,一半有n/2个数据元素,而另一半有n/2个数据元素。 先分别找出各自组中的最大元,然后将两个最大元进行比较,就可得n个元素的最大元

    代码如下:

    #include <iostream>
    #include <algorithm>
    #include <stdio.h>
    #include <string.h>
    #include <math.h>
    #include <stdlib.h>
    #include <set>
    #include <queue>
    #include <vector>
    using namespace std;
    
    int calc(int a[],int l,int r)
    {
        if(l==r) return a[l];
        return max(calc(a,l,(l+r)/2),calc(a,(l+r)/2+1,r));
    }
    
    int main()
    {
        int a[1005];
        int n;
        cout<<"数列长度: "<<endl;
        scanf("%d",&n);
        if(n==0) {puts("数列长度不能为0!"); return 0;}
        cout<<"请输入数列: "<<endl;
        for(int i=0;i<n;i++) scanf("%d",&a[i]);
    
        printf("这个数列的最大元为: %d
    ",calc(a,0,n-1));
        return 0;
    }
  • 相关阅读:
    349、两个数组的交集 | JS集合
    JS集合Set
    JS里的队列和链表
    使用链表指针获取JSON的节点值
    141、环形链表 | JS-链表
    83、删除排序链表中的重复元素 | JS-链表
    2、两数相加 | JS-链表
    事件循环与任务队列
    933、最近的请求次数 | JS-队列
    栈JS实现
  • 原文地址:https://www.cnblogs.com/chen9510/p/5896696.html
Copyright © 2011-2022 走看看