C++贪心算法

关于string的系统函数!

(注:以下函数只可用于string,不适用其他类型的变量)

① a.size();

这个系统函数是用来获取这个string变量的长度的,我们通常会新建一个变量来保存他,以便之后使用。

② sort(a[x],a[y]); (x,y代表一个数字,x是起始点,y是结束点)

这个系统函数是用来对string变量进行排序的(按字典序列),在排列型问题中很实用。

③ reverse(a[x],a[y]);

与前一个系统函数一样,这个也是用来给string变量排序的,只不过是逆序。

④ a.find(b); (a和b代表两个string变量)

这个系统函数是用来查找的,可以在a变量中查找b,如果b存在于a,就是true,反之亦然。

此外,还有4个系统函数我没有公布出来,如果这篇文章点赞超50,并且通过这篇文章关注我的人超过10个,下篇文章我就全部拿出来!

正文开始!

排队打水

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n,r;
	cin>>n>>r;
	int a[1010]={0};
	int b[1010]={0};
	for(int i=0;i<n;i++)
	{
		cin>>a[i];
	}
	sort(a+0,a+n);
	int sum=a[0];
	b[0]=a[0];
	for(int i=1;i<n;i++)
	{
		if(i<r)b[i]=a[i];
		else b[i]=b[i-r]+a[i];
		sum=sum+b[i];
	}
	cout<<sum;


	return 0;
}

活动选择

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
    int n;
	cin>>n;
	int a[110][110]={0};
	for(int i=0;i<n;i++)
	{
		cin>>a[0][i]>>a[1][i];
	}
	for(int i=0;i<n-1;i++)
	{
		for(int j=0;j<n-1-i;j++)
		{
			if(a[1][j]>a[1][j+1])
			{
				swap(a[1][j],a[1][j+1]);
				swap(a[0][j],a[0][j+1]);
			}
		}
	}
	int cnt=1;
	int t=a[1][0];
	while(true)
	{
		int cnt2=0;
		for(int i=0;i<n;i++)
		{
			if(a[1][i]==t)break;
			else cnt2++;
		}
		bool f=false;
		int tt;
		for(int i=cnt2+2;i<n;i++)
		{
			if(a[0][i]>=a[1][cnt2+1])
			{
				f=true;
				tt=i;
				break;
			}
		}
		if(f==false)
		{
			cout<<cnt<<endl;
			return 0;
		}
		else
		{
			cnt++;
			t=a[1][tt];
		}
	}
	
    
	return 0;
}

拦截导弹的系统数量求解

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main()
{
	int n;
    cin>>n;
	int a[110]={0};
	for(int i=0;i<n;i++)
	{
		cin>>a[i];
	}
	int cnt=n;
	int sum=0;
	while(cnt!=0)
	{
		sum++;
		int max=a[0];
		for(int i=0;i<n;i++)
		{
			if(a[i]<=max)
			{
				max=a[i];
				for(int j=i;j<n-1;j++)
				{
					a[j]=a[j+1];
				}
				a[n-1]=0;
				n--;
				i--;
			}
		}
		cnt=n;
	}
	cout<<sum;
    
    
	return 0;
}
相关推荐
SteveSenna7 分钟前
强化学习4.1:基于价值——Q-learning
人工智能·学习·算法·机器人
少许极端9 分钟前
算法奇妙屋(四十四)-贪心算法学习之路11
java·学习·算法·贪心算法
子琦啊9 分钟前
【算法复习】数组与双指针篇
javascript·算法
ambition2024211 分钟前
斐波那契取模问题的深入分析:为什么提前取模是关键的
c语言·数据结构·c++·算法·图论
逆境不可逃25 分钟前
LeetCode 热题 100 之 230. 二叉搜索树中第 K 小的元素 199. 二叉树的右视图 114. 二叉树展开为链表
算法·leetcode·职场和发展
一个有温度的技术博主30 分钟前
Redis Cluster 核心原理:哈希槽与数据路由实战
redis·算法·缓存·哈希算法
wfbcg41 分钟前
每日算法练习:LeetCode 15. 三数之和 ✅
算法·leetcode·职场和发展
2301_822703201 小时前
开源鸿蒙跨平台Flutter开发:跨端图形渲染引擎的类型边界与命名空间陷阱:以多维雷达图绘制中的 dart:ui 及 StrokeJoin 异常为例
算法·flutter·ui·开源·图形渲染·harmonyos·鸿蒙
y = xⁿ1 小时前
【LeetCode Hot100】双指针:分离指针
算法·leetcode
学习永无止境@1 小时前
Verilog中有符号数计算
图像处理·算法·fpga开发