【蓝桥杯】第十四届蓝桥杯大赛软件赛国赛C/C++ 大学 B 组

news2024/11/18 15:46:53

答题结果页 - 蓝桥云课 (lanqiao.cn)

0子2023 - 蓝桥云课 (lanqiao.cn)(暴力枚举

#include<bits/stdc++.h>
using ll=long long;
using ull=unsigned long long;
#define fir first
#define sec second
//#define int ll

const int N=1e5+10;
const int mod=1e9+7;

int a[N],b[N];

void solve()
{
//    std::string s;
//    std::map<int,std::vector<int>> mp;
//	for(int i=1;i<=2023;i++)
//	{
//		s+=std::to_string(i);
//	} 
//	//std::cout<<s<<'\n';
//	for(int i=0;i<s.length();i++)
//	{
//		if(s[i]=='2'||s[i]=='0'||s[i]=='3')
//		{
//			mp[s[i]].push_back(i);
//		}
//	}
//	ull ans=0;
//	for(auto i:mp['2'])
//	{
//		for(auto j:mp['0'])
//		{
//			if(j<i) continue;
//			for(auto k:mp['2'])
//			{
//				if(k<j) continue;
//				for(auto p:mp['3'])
//				{
//					if(p<k) continue;
//					ans++;
//				}
//			}
//		}
//	}
//	std::cout<<ans;
	std::cout<<"5484660609";
}
signed main()
{
    //freopen("a","w",stdout);//把结果输出到a.in里面
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    //std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

0双子数 - 蓝桥云课 (lanqiao.cn)(暴力枚举

懒得再写一遍【蓝桥杯】国赛普及--CSDN博客

#include<bits/stdc++.h>
using ll=unsigned long long;
#define int ll
const int N=2e5+10;
int k=0;
std::string s;
int a,b,c,d;
bool isprime(int x)
{
	for(int i=2;i<=x/i;i++)
	{
		if(x%i==0) return false;
	}
	return true;
}
void solve()
{
	char op;
	std::cin>>op;
	if(op=='A')
	{
		std::string s;
		for(int i=1;i<=2023;i++)
		{
			s+=std::to_string(i);	
		}	
		//std::cout<<s;
		std::cout<<5484660609<<'\n';
		ll ans=0;
		int len=s.length();
		
		std::vector<int> v1;
		std::vector<int> v2;
		std::vector<int> v3;
		for(int i=0;i<len;i++)
		{
			if(s[i]=='2') v1.push_back(i);
			if(s[i]=='0') v2.push_back(i);
			if(s[i]=='3') v3.push_back(i);
		}
		
		for(int i=0;i<v1.size();i++)
		{
			for(int j=0;j<v2.size();j++)
			{
				if(v2[j]<=v1[i]) continue;
				
				for(int k=i+1;k<=v1.size();k++)
				{
					if(v1[k]<=v2[j]) continue;
					
					for(int p=0;p<v3.size();p++)
					{
						if(v3[p]<=v1[k]) continue;
						ans++;
					}
				}
			}
		}
		std::cout<<ans<<'\n';
	}else{
//		for(int i=1;i<=110000000;i++)
//		{
//			if(i*i>=23333333333333)
//			{
//				std::cout<<i;
//				break;
//			}
//		}
//4830549
		std::vector<int> v;
		for(int i=2;i<=5000000;i++)
		{
			if(isprime(i)) v.push_back(i);
		}
		//std::cout<<v.size()<<"xxx\n";
		ll ans=0;
		for(int i=0;i<v.size();i++)
		{
			for(int j=i+1;j<v.size();j++)
			{
				if((double)v[i]*v[i]*v[j]*v[j]<=23333333333333&&v[i]*v[i]*v[j]*v[j]>=2333) ans++;
				if((double)v[i]*v[i]*v[j]*v[j]>23333333333333) break;
			}
		}
		std::cout<<ans<<'\n';
		//947293
	} 
}
signed main()
{
	std::ios::sync_with_stdio(false);
	std::cin.tie(0);
	
	int t=1;
	//std::cin>>t;
	while(t--)
	{
		solve();
	}
	return 0;
} 

0班级活动 - 蓝桥云课 (lanqiao.cn)(思维题

这题要点思维吧。

我们先数一数可以凑成几对,也就是有几个数的count值大于等于2,记为cnt。然后我们来讨论一下可能的情况:

如果是1 2 2 3这种情况,2凑成了一队剩下的就是1 3,这两个数不是重复的我们随便改一个即可,答案就是(n-cnt*2)/2。

如果是1 2 2 2 2 3,2凑成了一队,剩下1 2 2 3,因为与已经成队的2重复的有2个,因此必须要把这两个改了,然后发现改完可以是1 1 3 3,答案就是2。

因此我们的答案就是在差的队数和重复的必须要改的数中取一个最大值。

#include<bits/stdc++.h>
using ll=long long;
#define int ll
const int N=1e5+10;
int n;
int a[N];
void solve()
{
	std::cin>>n;
	std::map<int,int> mp;
	for(int i=1;i<=n;i++)
	{
		std::cin>>a[i];
		mp[a[i]]++;
	}
	ll ans=0,cnt=0;
	for(auto i:mp)
	{
		if(i.second>=2) 
    {
      cnt++;//成对的个数 
      ans+=i.second-2;
    }
	}
  std::cout<<std::max((n-cnt*2)/2,ans);
}
signed main()
{
	std::ios::sync_with_stdio(false);
	std::cin.tie(0);
	
	int t=1;
	//std::cint>>t;
	while(t--)
	{
		solve();
	}
	return 0;
} 

0合并数列 - 蓝桥云课 (lanqiao.cn)(思维题

题意就是给两个数组,这俩数组的和相同,求问最少合并几次能把这俩数组变得一样。

这个题面感觉挺像cf的。

这题突破点就是第一个数字只能和后面的合并,因此一旦第一个数字不同就必须要向后合并。因此我们开两个双端队列进行模拟,每次看队头两个数字是否相同,相同就同时出队,否则把小的那一端出队往后合并。其实就是双指针的思想,双端队列比较好实现。

#include<bits/stdc++.h>
using ll=long long;
using ull=unsigned long long;
#define fir first
#define sec second
#define int ll

const int N=1e5+10;
const int mod=1e9+7;

int a[N],b[N];
std::deque<ll> l,r; 
void solve()
{
	int n,m;
	std::cin>>n>>m;
	
	for(int i=1;i<=n;i++)
	{
		std::cin>>a[i];
		l.push_back(a[i]);
	}
	for(int i=1;i<=m;i++)
	{
		std::cin>>b[i];
		r.push_back(b[i]);
	}
	
	ll ans=0;
	while(l.size())
	{
		auto x=l.front(),y=r.front();
		
		if(x==y) l.pop_front(),r.pop_front();
		else if(x<y){
			l.pop_front();
			auto k=l.front();
			l.pop_front();
			l.push_front(k+x);
			ans++;
		}else{
			r.pop_front();
			auto k=r.front();
			r.pop_front();
			r.push_front(k+y);
			ans++;
		}
	}
	std::cout<<ans<<'\n';
}
signed main()
{
    //freopen("a","w",stdout);//把结果输出到a.in里面
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    //std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

0数三角 - 蓝桥云课 (lanqiao.cn)(模拟

就是从n个点里选3个,问有几种选法能组成等腰三角形。

被卡常卡了一下午,最后群里大佬帮我改的。

jrz,神!

#include<bits/stdc++.h>
using ll=long long;
using ull=unsigned long long;

#define fir first
#define sec second
//#define int ll

using PII=std::pair<int,int> ;
const int N=2e3+10;
const int mod=1e9+7;
const double eps=1e-6;


double dis(PII& c,PII& d)
{
    return (c.fir-d.fir)*(c.fir-d.fir)+(c.sec-d.sec)*(c.sec-d.sec);
}
bool line(PII& a,PII& b,PII& c)//共线返回yes
{
    if(a.sec==b.sec||a.sec==c.sec)
    {
        return  a.sec==b.sec && a.sec==c.sec;//纵坐标相同得全相同才共线
    }

    double k1=((a.fir-b.fir)*1.0/(a.sec-b.sec));
    double k2=((a.fir-c.fir)*1.0/(a.sec-c.sec));

    return std::abs(k1-k2)<eps;
}
void solve()
{
    int n;
    std::cin>>n;
    std::vector<PII> a;
    
    for(int i=0;i<n;i++)
    {
        int x,y;
        std::cin>>x>>y;
        a.emplace_back(x,y);
    }
    
	  std::vector< std::map<double,std::vector<int>> > mp(n);
    ll ans=0;

    for(int i=0;i<n;i++)
    {
        auto s=mp[i];

        for(int j=0;j<n;j++)
        {
            if(i==j) continue;

            double d=dis(a[i],a[j]);
            s[d].push_back(j);//存下与第i个点距离为d的坐标
        }

        for(const auto& j:s)
        {
            auto& ss=j.sec;
            for(int p=0;p<ss.size();p++)
            {
                for(int q=p+1;q<ss.size();q++)
                {
                    if(line(a[i],a[ss[p]],a[ss[q]])) continue;
                    ans++;
                }
            }
        }
    }
    std::cout<<ans<<'\n';
}
signed main()
{
    //freopen("a","w",stdout);//把结果输出到a.in里面
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    //std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

 0删边问题 - 蓝桥云课 (lanqiao.cn)(强连通分量

强连通分量不会,跳了。

 0AB路线 - 蓝桥云课 (lanqiao.cn)(BFS

唉,代码写了三个版本。

第一个版本只标记是否走过这点,很显然是不对的,有些点需要重复走,只有30%。

第二个版本四位数组,最后2位分别记录走过几次a和几次,但是会爆数组,只有80%。

第三个版本,因为已知前一个点,那么也就知道它的状态,我们无需知道a和b走过多少次,只需要知道上一个点在当轮走过多少次。 然后就是答案输出距离,好久没写bfs我还卡了一下,直接写个dis数组,初始化为-1标记距离就好。

#include<bits/stdc++.h>
using ll=long long;
using ull=unsigned long long;

#define fir first
#define sec second
//#define int ll

using PII=std::pair<int,int> ;
using ari=std::array<int,3>;
const int N=1e3+10;
const int mod=1e9+7;
const double eps=1e-6;

char g[N][N];
int n,m,k;
int st[N][N][11]; 
//求出满足条件的最短的路
//必须先k个a再k个b
int dx[]={1,0,-1,0};
int dy[]={0,-1,0,1};

ll ans=0; 
void bfs(int x,int y)
{
	std::queue<ari> q;
	q.push({x,y,1});
	st[x][y][1]=0;
	
	while(q.size())
	{
		auto t=q.front();
		q.pop();
		
		if(t[0]==n&&t[1]==m)
		{
			std::cout<<st[n][m][t[2]]<<'\n';
			return ;
		}
		
		for(int i=0;i<4;i++)
		{
			int a=t[0]+dx[i];
			int b=t[1]+dy[i];
			
			if(a<1||b<1||a>n||b>m) continue;
			
			if(t[2]==k)
			{
				if(g[a][b]==g[t[0]][t[1]]) continue;
				if(st[a][b][1]!=-1) continue;
				
				q.push({a,b,1});
				st[a][b][1]=st[t[0]][t[1]][t[2]]+1;
			}else{
				
				if(g[a][b]!=g[t[0]][t[1]]) continue;
				if(st[a][b][t[2]+1]!=-1) continue;
				
				q.push({a,b,t[2]+1});
				st[a][b][t[2]+1]=st[t[0]][t[1]][t[2]]+1;
			}
		}
	}
	std::cout<<-1<<'\n';
}
void solve()
{
    std::cin>>n>>m>>k;
    
    memset(st,-1,sizeof st);
    
    for(int i=1;i<=n;i++)
    {
    	for(int j=1;j<=m;j++)
    	{
    		std::cin>>g[i][j];
		}
	}
	bfs(1,1);
}
signed main()
{
    //freopen("a","w",stdout);//把结果输出到a.in里面
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    //std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

0抓娃娃 - 蓝桥云课 (lanqiao.cn)(二分

首先看到这个题目就感觉透着一股二分左右端点的味,然后就是要注意到一个条件,没有这个条件的话感觉难很多。

这个条件的意思就是前n个线段的长度全都比任一一个区间的长度要小。

然后我们稍微画个图看看,会发现如果一个线段的中点在区间L的左边或者在R的右边,包不行的。如果在中间呢?由条件这个线段的长度一定是小于当前区间长度,线段被完全包含在这块区间内很显然是可以的,因此我们只讨论线段有一部分在线段外的情况。

如果需要一半区间都在外面,则l必须比L小,此时线段的长度比区间大不满足题目条件。

因此,我们只要找有多少条线段的中点在L,R中即可。

因为double比较麻烦,我们直接同时乘以2。

#include<bits/stdc++.h>
using ll=long long;
using ull=unsigned long long;

#define fir first
#define sec second
//#define int ll

using PII=std::pair<int,int> ;
using ari=std::array<int,3>;
const int N=1e5+10;
const int mod=1e9+7;
const double eps=1e-6;

int n,m;
void solve()
{
    std::cin>>n>>m;
    //L<=(l+r)/2<=R
    //2*L<=(l+r)<=R*2
    
    std::vector<int> a(n);
    
    for(int i=0;i<n;i++)
    {
    	int l,r;
    	std::cin>>l>>r;
    	a[i]=l+r;
	}
	std::sort(a.begin(),a.end());
	
	for(int i=0;i<m;i++)
	{
		int l,r;
		std::cin>>l>>r;
		l*=2,r*=2;
		
		int L=std::lower_bound(a.begin(),a.end(),l)-a.begin();
		int R=std::upper_bound(a.begin(),a.end(),r)-a.begin();
		
		std::cout<<R-L<<'\n';
	}
}
signed main()
{
    //freopen("a","w",stdout);//把结果输出到a.in里面
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    //std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

0拼数字 - 蓝桥云课 (lanqiao.cn)(dp不会,唉

0逃跑 - 蓝桥云课 (lanqiao.cn)(dp不会,唉

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1710563.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用prometheus监测MySQL主从同步状态方案

说明&#xff1a;本文介绍如何使用prometheus、alertmanager监测MySQL主从&#xff0c;当从节点中断同步时&#xff0c;发送邮箱报警&#xff0c;并使用grafana将数据视图化。 结构图如下&#xff1a; 安装 &#xff08;1&#xff09;安装应用 首先&#xff0c;来安装promet…

谷歌推出TransformerFAM架构,以更低的消耗处理长序列文本

Transformer对大模型界的影响力不言而喻&#xff0c;ChatGPT、Sora、Stable Difusion等知名模型皆使用了该架构。 但有一个很明显的缺点&#xff0c;其注意力复杂度的二次方增长在处理书籍、PDF等超长文档时会显著增加算力负担。 虽然会通过滑动窗口注意力和稀疏注意力等技术…

全栈实现图片验证码及知识补充 全栈开发之路——全栈篇(4)

全栈开发一条龙——前端篇 第一篇&#xff1a;框架确定、ide设置与项目创建 第二篇&#xff1a;介绍项目文件意义、组件结构与导入以及setup的引入。 第三篇&#xff1a;setup语法&#xff0c;设置响应式数据。 第四篇&#xff1a;数据绑定、计算属性和watch监视 第五篇 : 组件…

100个 Unity小游戏系列六 -Unity 抽奖游戏专题四 翻卡游戏

一、演示效果 二、知识点讲解 2.1 布局 void CreateItems(){reward_data_list reward_data_list ?? new List<RewardData>();reward_data_list.Clear();for (int i 0; i < ItemCount; i){GameObject item;if (i 1 < itemParent.childCount){item itemParent…

AI革命:生活无处不智能

AI革命&#xff1a;生活无处不智能 &#x1f604;生命不息&#xff0c;写作不止 &#x1f525; 继续踏上学习之路&#xff0c;学之分享笔记 &#x1f44a; 总有一天我也能像各位大佬一样 &#x1f3c6; 博客首页 怒放吧德德 To记录领地 &#x1f31d;分享学习心得&#xff0…

PyBullet 物理引擎

PyBullet是一个开源的物理仿真库&#xff0c;基于Bullet Physics SDK这一成熟的、广泛使用的开源物理引擎。它提供了Python接口&#xff0c;使开发者能够利用Bullet强大的物理仿真能力&#xff0c;同时享受Python的易用性。PyBullet支持多种物理学模型&#xff0c;如刚体、骨骼…

CTF流量分析之wireshark使用

01.基本介绍 在CTF比赛中&#xff0c;对于流量包的分析取证是一种十分重要的题型。通常这类题目都是会提供一个包含流量数据的pcap文件&#xff0c;参赛选手通过该文件筛选和过滤其中无关的流量信息&#xff0c;根据关键流量信息找出flag或者相关线索。 pcap流量包的分析通常…

在 GPT-4o 释放完整能力前,听听实时多模态 AI 创业者的一手经验 | 编码人声

「编码人声」是由「RTE开发者社区」策划的一档播客节目&#xff0c;关注行业发展变革、开发者职涯发展、技术突破以及创业创新&#xff0c;由开发者来分享开发者眼中的工作与生活。 5 月中旬 GPT-4o 的发布&#xff0c;让人与 AI 的交互&#xff0c;从对话框的文本交流加速推进…

【C语言深度解剖】(14):结构体内存对齐(详细配图讲解)

&#x1f921;博客主页&#xff1a;醉竺 &#x1f970;本文专栏&#xff1a;《C语言深度解剖》 &#x1f63b;欢迎关注&#xff1a;感谢大家的点赞评论关注&#xff0c;祝您学有所成&#xff01; ✨✨&#x1f49c;&#x1f49b;想要学习更多C语言深度解剖点击专栏链接查看&…

【网络层】ICMP 因特网控制协议

文章目录 ICMP 含义以及作用ICMP协议解析结合ICMP协议和ping常见问题 ICMP 含义以及作用 ICMP&#xff1a;Internet control massage protocol 因特网控制协议 Internet控制报文协议ICMP是网络层的一个重要协议。 ICMP协议用来在网络设备间传递各种差错和控制信息&#xff0c;…

QA测试开发工程师面试题满分问答25: JVM瓶颈分析,举例说明

回答思路 JVM 性能瓶颈概述: JVM (Java Virtual Machine)是 Java 程序运行的基础环境,其性能直接影响到应用程序的整体性能。在实际项目中,我们经常会遇到 JVM 性能瓶颈,导致应用程序出现响应缓慢、CPU 利用率高、内存溢出等问题。因此,分析和诊断 JVM 瓶颈是非常重要的工作,有…

谷歌插件编写

目录 manifest.json {"manifest_version": 3,"name": "Floating Ball","version": "1.0","description": "A floating ball on the right side of the webpage.","permissions": ["act…

XS2185一款八通道以太网供电控制器

XS2185是一款八通道以太网供电控制器。 XS2185通过侦测各通道的DET管脚输入电压 来判断是否有合格的负载/PD接入系统&#xff0c;以决定 是否开启MOS供电开关。 当通道已经处于供电状态时&#xff0c;XS2185通过侦 测SENSE管脚的输入电压&#xff0c;以判断供电是否发生 …

Kubernetes部署dashboard

Kubernetes部署dashboard Kubernetes集群安装 鲲鹏arm64架构下安装KubeSphere linux安装部署k8s(kubernetes)和解决遇到的坑 dashboard部署 $ kubectl apply -f https://raw.githubusercontent.com/kubernetes/dashboard/master/src/deploy/recommended/kubernetes-dashbo…

电脑出现:excel词典(xllex.dll)文件丢失或损坏的错误提示怎么办?有效的将丢失的xllex.dll修复

当遇到 Excel 提示“词典 (xllex.dll) 文件丢失或损坏”的问题时&#xff0c;通常意味着该动态链接库文件&#xff08;Dynamic Link Library&#xff0c;DLL&#xff09;&#xff0c;它与拼写检查功能相关联的&#xff0c;无法被正确找到或者合适地使用。那么有什么办法可以解决…

【ARM+Codesys案例】T3/RK3568/树莓派+Codesys锂电叠片机方案:结合CODESYS实现高效生产

锂电叠片机解决方案 乘风破浪&#xff0c;促进新能源行业发展 锂电池是依靠锂离子在正极与负极之间移动来达到充放电目的的一种可充电电池&#xff0c;具有高能量密度、高电压、寿命长、无记忆效应等优点。锂电池属于国家政策扶持的高速发展行业&#xff0c;近年发展快速&…

开发者的福音:免去搭建服务,让你的应用开发变得像吃蛋糕一样简单!

传统应用开发的"噩梦" 想象一下&#xff0c;你正在准备一场盛大的晚宴&#xff0c;但必须从零开始建造厨房、种植食材、甚至学习烹饪技巧。这就是传统应用开发的现状——你不仅要设计数据库、编写API接口&#xff0c;还要处理对象存储、实时数据库、云数据库等一系列…

LeetCode - 双指针(Two Pointers) 算法集合 [对撞指针、快慢指针、滑动窗口、双链遍历]

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/139270999 双指针算法是一种常见且灵活的技巧&#xff0c;通过使用两个指针协同完成任务。这些指针可以指向不同的元素&#xff0c;具体应用取决于…

如何将红酒配餐融入日常生活

红酒配餐不仅可以提升用餐的品质&#xff0c;还可以为日常生活增添一份优雅和情调。云仓酒庄雷盛红酒以其卓着的品质和丰富的口感&#xff0c;成为了实现红酒配餐融入日常生活的理想选择。下面将介绍如何将雷盛红酒配餐融入日常生活。 首先&#xff0c;了解红酒的基本知识。了解…

动态规划part01 Day41

动态规划算法解题步骤 确定dp数组&#xff08;dp table&#xff09;以及下标的含义确定递推公式dp数组如何初始化确定遍历顺序举例推导dp数组 LC509斐波那契数 LC70爬楼梯 LC746使用最小花费爬楼梯 dp[]含义&#xff1a;爬到第i层楼梯的最小花费