• POJ3253(Fence Repair)


    训练优先队列的好题。

    题目大意:给一块长木板,现要将其锯成n段,共需锯n-1次,每次锯的代价为所锯木板的长度,求最小总代价。

    其实也可以看成是把n段木板拼成一块,每次拼的代价为所拼木板的长度和。这就跟哈夫曼编码一样,每次选取两个最小的来拼。具体实现时用优先队列。

    代码:

    #include<cstdio>
    #include<queue>
    #include<cstdlib>
    #include<cstring>
    #include<iostream>
    #include<algorithm>
    
    using namespace std;
    priority_queue<int ,vector<int>,greater<int> >Q;//优先队列从小到大排列
    int main()
    {
        int n;
        while(scanf("%d",&n)!=EOF)
        {
            int ce;
            for(int i=0;i<n;i++)
            {
                scanf("%d",&ce);
                Q.push(ce);
            }
            long long mincost=0;
            while(Q.size()>1)
            {
                int x=Q.top();
                Q.pop();
                int y=Q.top();
                Q.pop();
                mincost+=(x+y);
                Q.push(x+y);
            }
            printf("%lld
    ",mincost);
            while(!Q.empty())
                Q.pop();
        }
        return 0;
    }

    下面是优先队列的用法。

    在优先队列中,优先级高的元素先出队列。
    标准库默认使用元素类型的<操作符来确定它们之间的优先级关系。
    优先队列的第一种用法,也是最常用的用法:

    priority_queue<int> qi;

    通过<操作符可知在整数中元素大的优先级高。
    故示例1中输出结果为:9 6 5 3 2

    第二种方法:
    在示例1中,如果我们要把元素从小到大输出怎么办呢?
    这时我们可以传入一个比较函数,使用functional.h函数对象作为比较函数。

    priority_queue<int, vector<int>, greater<int> >qi2;

    其中
    第二个参数为容器类型。
    第二个参数为比较函数。
    故示例2中输出结果为:2 3 5 6 9

    第三种方法:
    自定义优先级。

    struct node
    {
        
    friend bool operator< (node n1, node n2)
        {
            
    return n1.priority < n2.priority;
        }
        
    int priority;
        
    int value;
    };

    在该结构中,value为值,priority为优先级。
    通过自定义operator<操作符来比较元素中的优先级。
    在示例3中输出结果为:
    优先级  值
    9          5
    8          2
    6          1
    2          3
    1          4
    但如果结构定义如下:

    struct node
    {
        
    friend bool operator> (node n1, node n2)
        {
            
    return n1.priority > n2.priority;
        }
        
    int priority;
        
    int value;
    };

    则会编译不过(G++编译器)
    因为标准库默认使用元素类型的<操作符来确定它们之间的优先级关系。
    而且自定义类型的<操作符与>操作符并无直接联系,故会编译不过。

    //代码清单

    #include<iostream>
    #include
    <functional>
    #include
    <queue>
    using 
    namespace std;
    struct node
    {
        
    friend bool operator< (node n1, node n2)
        {
            
    return n1.priority < n2.priority;
        }
        
    int priority;
        
    int value;
    };
    int main()
    {
        
    const int len = 5;
        
    int i;
        
    int a[len= {3,5,9,6,2};
        
    //示例1
        priority_queue
    <int> qi;
        
    for(i = 0; i < len; i++)
            qi.push(a[i]);
        
    for(i = 0; i < len; i++)
        {
            cout
    <<qi.top()<<" ";
            qi.pop();
        }
        cout
    <<endl;
        
    //示例2
        priority_queue
    <int, vector<int>, greater<int> >qi2;
        
    for(i = 0; i < len; i++)
            qi2.push(a[i]);
        
    for(i = 0; i < len; i++)
        {
            cout
    <<qi2.top()<<" ";
            qi2.pop();
        }
        cout
    <<endl;
        
    //示例3
        priority_queue
    <node> qn;
        node b[
    len];
        b[
    0].priority = 6; b[0].value = 1
        b[
    1].priority = 9; b[1].value = 5
        b[
    2].priority = 2; b[2].value = 3
        b[
    3].priority = 8; b[3].value = 2
        b[
    4].priority = 1; b[4].value = 4

        
    for(i = 0; i < len; i++)
            qn.push(b[i]);
        cout
    <<"优先级"<<' '<<"值"<<endl;
        for(i = 0; i < len; i++)
        {
            cout
    <<qn.top().priority<<' '<<qn.top().value<<endl;
            qn.pop();
        }
        
    return 0;
    }
    屌丝终有逆袭日,*******。
  • 相关阅读:
    FRAM在智能电子式电表中的应用
    element UI实现动态生成多级表头
    小微信小程序开发相关网站
    响应式开发bootstrap
    媒体查询
    前端导出功能实现的两种方式
    watch监听对象遇坑
    vue中使用v-for时为什么要用到key?为什么不能用index作为key?
    vue中我改变了data中的一个值,但现在视图上没有实时更新,请问我怎么拿到更新后的值?
    python 链接数据库的模块
  • 原文地址:https://www.cnblogs.com/ZhaoPengkinghold/p/3728168.html
Copyright © 2020-2023  润新知