【蓝桥每日一题]-贪心(保姆级教程 篇1)#拼数 #合并果子 #凌乱yyy

目录

[题目: 拼数](#题目: 拼数)

思路:

[题目: 合并果子](#题目: 合并果子)

思路:

题目:凌乱yyy

思路:


题目:拼数

思路:

思路很简单。举个例子:对于a=321,b=32。我们发现a+b=32132,b+a=32321,那么我们当然要后者,所以整个数组都按这个排列即可。

复制代码
#include <iostream>                 //拼数P1012
#include <algorithm>
#include <string>
using namespace std;
bool com(string a,string b)
{
	return a+b>b+a;               //对于a=321,b=32,a+b=32132,b+a=32321,
}                            	  

int main()
{
	string s[25];int n;cin>>n;
	for(int i=1;i<=n;i++) cin>>s[i];
	sort(s+1,s+n+1,com);
	for(int i=1;i<=n;i++) cout<<s[i];
	
	return 0;
}

题目:合并果子

思路:

贪心(每次都花费最少代价)我们合并后插入排序即可。

也可以直接使用优先级队列priority_queue,之所以priority_queue也可以通过是因为队伍里面本来就是有序的,再插入时排序极快。

复制代码
#include <iostream>                      
#include <algorithm>              
using namespace std;
int main(){
	int n,a[10001],ans=0;
	cin>>n;
	for(int i=0;i<n;i++)cin>>a[i];
	sort(a,a+n);
	for(int i=1;i<n;i++){
		ans+=a[i-1]+a[i];                      
		a[i]=a[i-1]+a[i];                 //把合并后的数放到a[i]
		for(int j=i+1;j<n;j++){
			if(a[j-1]>a[j])swap(a[j-1],a[j]);   //交换排序,覆盖排序都可以(因为都是一趟就行),就是不要快排(因为知道要几趟)
			else break;
		}
	}
	cout<<ans;
	return 0;
}

题目:凌乱yyy

思路:

我们只要按照结束时间去即可,然后能赶上这个比赛就参加,不能就不参加。没了

复制代码
#include <iostream>                         
#include <algorithm>
using namespace std;
struct text{
	int sta;
	int end;
};
bool cmp(text a,text b)                      //当下最优化,谁先结束,就选谁
{
	return a.end<b.end;
}
int main()
{
	int n,ans=1;cin>>n;text line[n];         //共n场考试
	for(int i=0;i<n;i++) scanf("%d %d",&line[i].sta,&line[i].end);
	sort(line,line+n,cmp);                 //将其按结束时间排序
	int tem=line[0].end;
	for(int i=1;i<n;i++)
	if(tem<=line[i].sta){ans++;tem=line[i].end;}
	cout<<ans;
	return 0;
}
相关推荐
一方热衷.4 分钟前
YOLOv8/YOLOv11 C++ OpenCV DNN推理
c++·opencv·yolo
泥泞开出花朵22 分钟前
LRU缓存淘汰算法的详细介绍与具体实现
java·数据结构·后端·算法·缓存
ankleless41 分钟前
C语言(02)——标准库函数大全(持续更新)
c语言·开发语言·算法·标准库函数·零基础自学
玖剹1 小时前
Linux文件系统:从内核到缓冲区的奥秘
linux·c语言·c++·笔记·ubuntu
补三补四1 小时前
Shapley与SHAP
大数据·人工智能·算法·机器学习·数据分析
KarrySmile1 小时前
Day17--二叉树--654. 最大二叉树,617. 合并二叉树,700. 二叉搜索树中的搜索,98. 验证二叉搜索树
数据结构·算法·二叉树·二叉搜索树·合并二叉树·最大二叉树·验证二叉搜索树
凤年徐1 小时前
【数据结构与算法】21.合并两个有序链表(LeetCode)
c语言·数据结构·c++·笔记·算法·链表
程序员老冯头2 小时前
第三十二节 MATLAB函数
数据结构·算法·matlab
lifallen2 小时前
hadoop.yarn 带时间的LRU 延迟删除
java·大数据·数据结构·hadoop·分布式·算法
jdlxx_dongfangxing2 小时前
2024 年 NOI 最后一题题解
c++·noi