【作业】 贪心算法

T1

cpp 复制代码
#include <iostream>
#include <algorithm>
using namespace std;
struct soider{
	int B;
	int J;
};
bool cmp(soider a,soider b){
	return a.J>b.J;
}
soider a[1000010];
int n;
void solve(int n,int num){
	for(int i=0;i<n;i++){
		scanf("%d%d",&a[i].B,&a[i].J);
	}
	sort(a+0,a+n,cmp);
	int t=0;
	int work=0;
	for(int i=0;i<n;i++){
		t+=a[i].B;
		if(work>a[i].B)
			work-=a[i].B;
		else 
			work=0;
		work=max(a[i].J,work);
	}
	printf("Case %d:%d\n",num,t+work);
}
int main(){
	scanf("%d",&n);
	int cnt=1;
	while(n>0){
		solve(n,cnt);cnt++;
		scanf("%d",&n);
	}
	
	return 0;
}

时间复杂度约为

T2

cpp 复制代码
#include <iostream>
#include <algorithm>
#include <cmath>
using namespace std;
struct soider {
	double l;
	double r;
};//用这个名字是因为省事

bool cmp(soider a, soider b) {
	return a.l < b.l;
}
int d;
soider a[1000010];
int n;//[x-sqrt(d*d-y*y),x+sqrt(d*d+y*y)]
void solve(int num) {

	scanf("%d", &d);
	for (int i = 0; i < n; i++) {
		int x;
		int y;
		scanf("%d%d", &x, &y);

		if (d * d - y * y < 0) {
			cout << "-1" << endl;
			return;
		}
		a[i].l = x - sqrt(d * d - y * y);
		a[i].r = x + sqrt(d * d - y * y);
		//cout << 'l' << a[i].l << endl;
		//cout << 'r' << a[i].r << endl;

	}
	sort(a + 0, a + n, cmp);
	double p = a[0].r;
	int cnt = 1;
	int i = 0;
	while (p <= a[n - 1].r && i < n) {
		//cout<<"p:"<<p<<endl;
		while (a[i].l <= p) {
			i++;
			//cout <<i<< " l " << a[i].r << endl;
			//cout <<i<< " r " << a[i].r << endl;
		}
		p = a[i].r;
		cnt++;
	}
	cout << cnt << endl;
}
int main() {
	scanf("%d", &n);


	solve(n);



	return 0;
}

时间复杂度约为

相关推荐
Rabitebla39 分钟前
【C++】string 类:原理、踩坑与对象语义
linux·c语言·数据结构·c++·算法·github·学习方法
小雅痞2 小时前
[Java][Leetcode middle] 167. 两数之和 II - 输入有序数组
java·算法·leetcode
CN-Dust2 小时前
【C++】输入cin例题专题
java·c++·算法
数模竞赛Paid answer3 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
Old Uncle Tom8 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆9 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移9 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业9 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
空中海10 小时前
Kubernetes 入门基础与核心架构
贪心算法·架构·kubernetes
智者知已应修善业11 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机