美文网首页
2020-09-08 [USACO1.3]混合牛奶 Mixin

2020-09-08 [USACO1.3]混合牛奶 Mixin

作者: JalorOo | 来源:发表于2020-09-08 20:07 被阅读0次

https://www.luogu.com.cn/problem/P1208

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <sstream>
#include <algorithm>
#include <cstring>
#include <vector>
using namespace std;

template<typename DataType>
DataType qmi(DataType m, int k)
{
    DataType res = 1, t = m;
    while (k)
    {
        if (k&1) res = res * t;
        t = t * t;
        k >>= 1;
    }
    return res;
}

int read(){
    int x = 0,f = 1;
    char c = getchar();
    while (c<'0'||c>'9') {
        if (c=='-') {
            f = -1;
        }
        c = getchar();
    }
    while (c>='0'&&c<='9') {
        x = x*10+c-'0';
        c = getchar();
    }
    return x*f;
}

#define fi(a,b) for(int i = a; i <= b; i++)
#define fj(a,b) for(int j = a; j >= b; j--)

struct priceAndCnt{
    int price,cnt;
};

void quickSort(priceAndCnt *a,int left,int right){
    int i,j;
    
    priceAndCnt temp,t;
    
    temp = a[(left+right)/2];//基准值
    
    i = left;
    j = right;
    
    while(i<=j){
        while (a[j].price > temp.price) {
            j--;
        }
        
        while (a[i].price < temp.price) {
            i++;
        }
        
        if (i<=j) {
            t = a[i];
            a[i] = a[j];
            a[j] = t;
            //继续下一步
            i++;
            j--;
        }
    }
    
    if(left<j)quickSort(a,left, j);//继续分治
    if(i<right)quickSort(a,i, right);//继续分治
}

int m,n,ans = 0;
priceAndCnt arr[2000005];
int main(){
    //输入部分
    n = read();
    m = read();
    fi(1, m){
        arr[i].price = read();
        arr[i].cnt = read();
    }
    
    //排序,然后一一匹配
    quickSort(arr, 1, m);
    
//    fi(1, m){
//        cout<<arr[i].price<<"\t"<<arr[i].cnt<<endl;
//    }
    fi(1, m){
        while(n && arr[i].cnt){
            n --;
            arr[i].cnt --;
            ans += arr[i].price;
        }
    }
    cout<<ans;
}
/*
100 5
5 20
9 40
3 10
8 80
6 30
============
6
*/

相关文章

  • 2020-09-08 [USACO1.3]混合牛奶 Mixin

    https://www.luogu.com.cn/problem/P1208

  • wepy小程序框架笔记

    一.Mixin混合 混合可以将组件公共部分抽出,组件中需要使用的时候直接注入就可以了。Mixin混合分为默认式混合...

  • 混合 mixin

    定义mixin 通过@include 名字 调用mixin mixin使用参数

  • 看看sass和less会遇到的问题吧

    sass的混合指令 mixin 混合指令(Mixin)用于定义可重复使用的样式,避免了使用无语意的 class,比...

  • Dart mixin继承机制

    Mix:混合In: 进入,加入Mixin: 混入 mixin 声明 属于dart 2.1 加入的特性。以前版本通常...

  • SASS - 混合(Mixin)

    SASS – 简介 SASS – 环境搭建 SASS – 使用Sass程序 SASS – SASS – 语法 SA...

  • vue.js的mixin

    前言 mixin译为混合,在vue中一般用于公共数据公共方法的提取,如果载入mixin的组件中拥有和mixin一样...

  • Scss中的混合宏、继承和占位符

    Sass中的混合宏、继承和占位符 一、混合宏 1.不带参数的混合宏 @mixin border-radius {-...

  • SCSS笔记5 - 混合器(混合宏)

    混合器@mixin和@include用于规则的复用 两者搭配使用,用于规则的复用。@mixin horizonta...

  • Sass混合的使用

    本节我们学习 Sass 中的混合,Sass 中的混合是通过 @mixin 指令来定义的,混合允许我们定义可以在整个...

网友评论

      本文标题:2020-09-08 [USACO1.3]混合牛奶 Mixin

      本文链接:https://www.haomeiwen.com/subject/xdvjektx.html