洛谷题单-贪心

  1. 洛谷题单-贪心

    牛奶 在这里插入图片描述在这里插入图片描述

    传送门 cpp #include <bits/stdc++.h> using namespace std; // https://www.luogu.com.cn/problem/P1208 struct node { int p; //价格 int t; //拥有的数量 } man[100000]; bool cmp(node a, node b) { return a.p < b.p; } int main() { ios::sync_with_stdio(false); int n, m; cin >> n >> m; for (int i = 1; i <= m; i++) { cin >> man[i].p >> man[i].t; } sort(man + 1, man + 1 + m, cmp); long long ans = 0; int cnt = 0; while (n) { if (n > man[++cnt].t) { ans += man[cnt].p * man[cnt].t; n -= man[cnt].t; } else { ans += man[cnt].p * n; n = 0; } } cout << ans; return 0; }

    跳跳! 在这里插入图片描述

    #include <bits/stdc++.h> using namespace std; // 贪心(在剩下的石头里找最大和最小来回跳) //
    https://www.luogu.com.cn/problem/P4995#submit int stone[100000]; int
    main() {
        ios::sync_with_stdio(false);
        cin.tie(0), cout.tie(0);
        int n;
        cin >> n;
        for (int i = 1; i <= n; i++)
        {
            cin >> stone[i];
        }
        sort(stone + 1, stone + 1 + n);
        int rnode = n;
        int lnode = 0; // lnode 初值为1!因为一开始在地面
        bool flag = true;
        long long ans = 0;
        while (lnode != rnode)
        {
            if (flag)
            {
                ans += (stone[rnode] - stone[lnode]) * (stone[rnode] - stone[lnode]);
                lnode++;
                flag = false;
            }
            else
            {
                ans += (stone[rnode] - stone[lnode]) * (stone[rnode] - stone[lnode]);
                rnode--;
                flag = true;
            }
        }
        cout << ans;
        return 0; } ```
    ### 纪念品分组 ![在这里插入图片描述](https://img-blog.csdnimg.cn/b467d16d231242078636be0d5e9cd2f9.png)
    
    [传送门](https://www.luogu.com.cn/problem/P1094) ```cpp
    #include <bits/stdc++.h> using namespace std; // https://www.luogu.com.cn/problem/P1094 int gift[100000]; int main()
    {
        int m, n, cnt;
        cin >> m >> n;
        for (int i = 1; i <= n; i++)
        {
            cin >> gift[i];
        }
        sort(gift + 1, gift + 1 + n);
        int rnode = n;
        int lnode = 1;
        cnt = 0;
        while (lnode < rnode)
        {
            if (gift[lnode] + gift[rnode] <= m)
            {
                cnt++;
                lnode++, rnode--;
            }
            else
            {
                rnode--;
                cnt++;
            }
        }
        if (lnode == rnode)
        {
            cnt++;
        }
        cout << cnt;
        return 0; } ```
    ### 三国游戏 ![在这里插入图片描述](https://img-blog.csdnimg.cn/801c46d9cbc34e2bae816890c413a3d9.png)
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/af32c24f09c94d45a4da06045614f5f7.png)
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/77064a078bdc445287c1e275e2b16e73.png)
    [传送门](https://www.luogu.com.cn/problem/P1199) ```cpp
    #include <bits/stdc++.h> using namespace std; int gen[10000][10000]; // 贪心+博弈论 // 每次选择第二大即可! int main() {
        ios::sync_with_stdio(false);
        cin.tie(0), cout.tie(0);
        int n;
        cin >> n;
        for (int i = 1; i < n; i++)
        {
            for (int j = i + 1; j <= n; j++)
            {
                cin >> gen[i][j];
                gen[j][i] = gen[i][j];
            }
        }
        int ans = -1;
        for (int i = 1; i <= n; i++)
        {
            sort(gen[i] + 1, gen[i] + 1 + n, greater<int>());
            ans = max(ans, gen[i][2]);
        }
        cout << 1 << endl;
        cout << ans << endl;
        return 0; } ```
    ### 推销员
    
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/32d69d1293bb4f11ade9082c00ca3f6a.png)
    ![在这里插入图片描述](https://img-blog.csdnimg.cn/a5c8b741d1a54e84a05120619d642889.png)
    [传送门](https://www.luogu.com.cn/problem/P2672) ```cpp
    #include <bits/stdc++.h> using namespace std; // https://www.luogu.com.cn/problem/P2672 int N; struct node {
        int dis;
        int tire; } a[100000]; int t[100000];    // t[i]代表前i个最大疲劳值前缀和 int d[100000];    // q[i]代表前i个最大疲劳值的用户中在距离花费的疲劳值 int post[100000];
    // post[i]代表挑去i个最大疲劳值用户之后,剩下之中的最大值 bool cmp(node a, node b) {
        return a.tire > b.tire; } int main() {
        ios::sync_with_stdio(false);
        cin.tie(0), cout.tie(0);
        cin >> N;
        for (int i = 1; i <= N; i++)
        {
            cin >> a[i].dis;
        }
        for (int i = 1; i <= N; i++)
        {
            cin >> a[i].tire;
        }
        sort(a + 1, a + 1 + N, cmp);
        for (int i = 1; i <= N; i++)
        {
            t[i] = t[i - 1] + a[i].tire;
        }
        for (int i = 1; i <= N; i++)
        {
            d[i] = max(d[i - 1], a[i].dis * 2);
        }
        for (int i = N; i >= 1; i--)
        {
            post[i] = max(post[i + 1], 2 * a[i].dis + a[i].tire);
        }
        for (int i = 1; i <= N; i++)
        {
            cout << max(t[i] + d[i], t[i - 1] + post[i]) << endl;
        }
        return 0; } ```
    
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值