• papamelon 212. 区间调度问题(挑战程序设计竞赛)


    地址 https://www.papamelon.com/problem/212

    解答
    贪心算法
    选择符合条件中区间结束比较早的那个区间。
    可以证明,同样的选择区间中,选择较早结束的区间至少不会得到比选择较晚结束的区间更差的结果。
    基于以上规则,我们将区间按照结束时间排序。
    每次选择起始时间比当前结束时间小的区间,该区间是可以选择的区间中结束时间最早的。即可

    // 1123555.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。
    //
    
    #include <iostream>
    #include <algorithm>
    
    using namespace std;
    /*
    5
    1 99
    2 5
    4 7
    6 9
    8 10
    输出
    3
    */
    
    const int N = 100010;
    struct Node {
    	int l; int r;
    }node[N];
    int n;
    
    bool cmp(const struct Node& a, const struct Node& b) {
    	return a.r < b.r;
    }
    
    void solve() {
    	sort(node, node + n, cmp);
    
    	int currEnd = -9999999;
    	int ans = 0;
    	for (int i = 0; i < n; i++) {
    		if (currEnd < node[i].l) {
    			ans++; currEnd = node[i].r;
    		}
    	}
    
    	cout << ans << endl;
    
    	return ;
    }
    
    int main()
    {
    	while (cin >> n) {
    		for (int i = 0; i < n; i++) {
    			int a, b;
    			cin >> a >> b;
    			if (a > b) { swap(a, b); }
    			node[i].l = a; node[i].r = b;
    		}
    
    		solve();
    	}
    
    	return 0;
    }
    

    我的视频题解空间

    作 者: itdef
    欢迎转帖 请保持文本完整并注明出处
    技术博客 http://www.cnblogs.com/itdef/
    B站算法视频题解
    https://space.bilibili.com/18508846
    qq 151435887
    gitee https://gitee.com/def/
    欢迎c c++ 算法爱好者 windows驱动爱好者 服务器程序员沟通交流
    如果觉得不错,欢迎点赞,你的鼓励就是我的动力
    阿里打赏 微信打赏
  • 相关阅读:
    Android Theme主题
    Android AbsoluteLayout绝对布局
    Android FrameLayout单帧布局
    Android TableLayout 表格布局
    Android LinearLayout线性布局
    Android RelativeLayout相对布局
    Unity中几种简单的相机跟随
    Android适配API23之后权限的动态申请
    natural gradient笔记
    优化整理
  • 原文地址:https://www.cnblogs.com/itdef/p/15613925.html
Copyright © 2020-2023  润新知