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;
}
相关推荐
程序员泡椒3 分钟前
二分查找Go版本实现
数据结构·c++·算法·leetcode·go·二分
小雨下雨的雨4 分钟前
Flutter鸿蒙共赢——墨染算法:柏林噪声与鸿蒙生态中的数字水墨意境
算法·flutter·华为·交互·harmonyos·鸿蒙
瑾修5 分钟前
golang查找cpu过高的函数
开发语言·后端·golang
kkkAloha10 分钟前
JS笔记汇总
开发语言·javascript·笔记
NAGNIP6 小时前
万字长文!回归模型最全讲解!
算法·面试
LawrenceLan6 小时前
Flutter 零基础入门(十一):空安全(Null Safety)基础
开发语言·flutter·dart
知乎的哥廷根数学学派6 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
txinyu的博客7 小时前
解析业务层的key冲突问题
开发语言·c++·分布式
码不停蹄Zzz7 小时前
C语言第1章
c语言·开发语言
行者967 小时前
Flutter跨平台开发在OpenHarmony上的评分组件实现与优化
开发语言·flutter·harmonyos·鸿蒙