蓝桥杯小白赛第六期 5.等腰三角形 知识点:三角形特性,贪心

思想

5.等腰三角形【算法赛】 - 蓝桥云课 (lanqiao.cn)

三角形两边之和大于第三边

ps

一定要排序,不然过不了

js 复制代码
#include<bits/stdc++.h>
using namespace std;
#define LL long long
LL ans=0;

int main()
{
	int n;cin>>n;
	vector<LL>a(n),b(n);
	for(int i=0;i<n;i++)cin>>a[i];
	for(int i=0;i<n;i++)cin>>b[i];
	

	int j=0;
	for(int i=0;i<n;i++)
	{
		if(a[i]*2>b[j])
		{
			j++,ans++;
		 } 
	 } 
	 cout<<ans;
	return 0;
 } 

js 复制代码
#include<bits/stdc++.h>
using namespace std;
#define LL long long
LL ans=0;

int main()
{
	int n;cin>>n;
	vector<LL>a(n),b(n);
	for(int i=0;i<n;i++)cin>>a[i];
	for(int i=0;i<n;i++)cin>>b[i];
	
	sort(a.begin(),a.end());
		sort(b.begin(),b.end());
	
	int j=0;
	for(int i=0;i<n;i++)
	{
		if(a[i]*2>b[j])
		{
			j++,ans++;
		 } 
	 } 
	 cout<<ans;
	return 0;
 } 

至于原因我们可以从样例看出来:

上面的样例是按照一一对应的样子给出的A和B。

如果说系统给的输入不是按照一一对应的给出的,那么A和B一一对应组合会产生很多无效组合。

因此我们需要排个序,让A对应B。

通过排序,我们可以在O(N^2)的时间复杂度内找到所有可能的红色木棍组合,并且在O(N)的时间复杂度内检查它们是否能与蓝色木棍构成等腰三角形。如果没有排序,每个红色木棍组合都需要O(N)的时间来检查所有蓝色木棍长度,总体时间复杂度将是O(N^3),这将使得算法在较大的N值下变得非常慢。

相关推荐
ZhengEnCi4 小时前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记4 小时前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan5 小时前
AI小镇 - 涌现
算法·架构
AI工程架构师8 小时前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
祈安_8 小时前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮1 天前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling1 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
颜酱1 天前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
CoovallyAIHub2 天前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
木心月转码ing2 天前
Hot100-Day14-T33搜索旋转排序数组
算法