GESP4级考试语法知识(贪心算法(六))

寻找平面上的极大点代码

cpp 复制代码
#include<iostream>
#include<algorithm>
using namespace std;
struct node
{
	int x,y;
}a[101];
bool vis[101];
bool cmp(node A,node B)
{
	if(A.x!=B.x) return A.x<B.x;
	return A.y<B.y;
}
int main()
{
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)
		cin>>a[i].x>>a[i].y;
	sort(a+1,a+n+1,cmp);
	for(int i=n;i>=1;i--)
	{
		for(int j=i-1;j>=1;j--)
		{
			if(!vis[j])
			{
				if(a[i].x>=a[j].x&&a[i].y>=a[j].y)
				{
					vis[j]=1;
				}
			}
		}
	}
	for(int i=1;i<=n-1;i++)
	{
		if(!vis[i])
		{
			cout<<"("<<a[i].x<<","<<a[i].y<<"),";
		}
	}
	cout<<"("<<a[n].x<<","<<a[n].y<<")";
 	return 0;
}

最大连续序列和代码:

cpp 复制代码
#include<iostream>
using namespace std;
int main()
{
    //最大连续序列和
    //1000 1 -2 3 -4 5       1003
    //-1 2 3 -4 5             6
    //-1 1 4 0 5             前缀和
    int n,a[100]={0};
    cin>>n;
    //输入数列并求前缀和
    for(int i=1;i<=n;i++)
    {
    	cin>>a[i];
    	a[i]+=a[i-1];
	}
	int maxn=a[1];
	for(int i=1;i<=n;i++)
	{
			for(int j=0;j<i;j++)
		{
			int temp=a[i]-a[j];//每一个区间和
			maxn=max(maxn,temp);
		}
    }
    cout<<maxn<<endl;
 	return 0;
}
相关推荐
@小柯555m6 小时前
Java八股刷题
java·开发语言·八股
时空自由民.6 小时前
三个按键的,短按1S,长按3S,单击,双击,三击的检测程序
大数据·数据库·计算机网络·算法
182******20836 小时前
2026新手必看:C语言学到什么程度可以出去找工作
c语言·开发语言
dog2506 小时前
圆锥曲线命题的定义和证明
网络·算法·php
IT猿手6 小时前
光伏模型参数估计:山羊优化算法(Goat Optimization Algorithm, GOA)求解光伏模型参数辨识问题,免费提供完整MATLAB代码链接
开发语言·算法·matlab·智能优化算法·光伏模型参数估计·光伏模型参数辨识·最新群智能算法
Cando学算法6 小时前
欧拉回路(一笔画)
数据结构·c++·图论
kels88996 小时前
2026 年黄金实时价格数据 API 接口实测推荐
开发语言·笔记·python·金融·区块链
嵌入式小企鹅7 小时前
大模型算法工程师面试宝典
人工智能·学习·算法·面试·职场和发展·大模型·面经
牢七7 小时前
链条合集整理
java·开发语言
我不是懒洋洋7 小时前
手写一个并查集:从原理到最小生成树实战
c语言·c++·经验分享·算法