2026牛客寒假算法基础集训营1

文章目录

L-Need Zero

解题思路

个位数的情况只有0~9,个位数为1,3,7,9时,x最小为10;个位数为5时,x最小为2;个位数为0时,x最小为1;个位数为52,6,8时,x最小为5;

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
#define int long long
#define PII pair<int,int>
#define fi first
#define se second
#define endl '\n'
const int N=1e6+6;
int n;
void solve()
{
	cin>>n;
	int x=n%10,k;
	if(x==1||x==3||x==7||x==9)k=10;
	else if(x==5)k=2;
	else if(x==0)k=1;
	else k=5;
	cout<<k<<endl;
}
signed main()
{
	IOS;
	int _=1;
//	cin>>_;
	while(_--)
	solve();
	return 0;
}

K-Constructive

解题思路

通过举例各种情况可得,只有n=1或3有满足情况的数组,当n=1时,数组:1。当n=3时,数组:1 2 3.可证明当n为其他数时不可能有满足情况的数组。

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
#define int long long
#define PII pair<int,int>
#define fi first
#define se second
#define endl '\n'
const int N=1e6+6;
int n,a[N];
void solve()
{
	cin>>n;
	if(n==1)
	{
		cout<<"YES"<<endl;
		cout<<1<<endl;
		return ;
	}
	else if(n==3)
	{
		cout<<"YES"<<endl;
		cout<<"1 2 3"<<endl;
		return ;
	}
	else
	cout<<"NO"<<endl;
}
signed main()
{
	IOS;
	int _=1;
	cin>>_;
	while(_--)
	solve();
	return 0;
}

C-Array Covering

解题思路

由于可以选择将开区间内的每个数变为端点最大值,可证明除了最左边和最右边端点不能改变,其余数都可以改变为数组中的最大值,再将结果相加即可,注意范围要开long long。

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
#define int long long
#define PII pair<int,int>
#define fi first
#define se second
#define endl '\n'
const int N=1e6+6;
int n,a[N];
void solve()
{
	cin>>n;
	int mx=-1;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
		mx=max(mx,a[i]);
	}
	if(n==1)cout<<a[1]<<endl;
    else if(n==2)cout<<(a[1]+a[2])<<endl;
    else cout<<(mx*(n-2)+a[1]+a[n])<<endl;
}
signed main()
{
	IOS;
	int _=1;
	cin>>_;
	while(_--)
	solve();
	return 0;
}

E-Block Game

解题思路

这道题简而言之就是在一个数组的最左侧插入一个数字,并也与最后一个数相连构成一个环,求这个环中相邻两个元素的最大值。

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
#define int long long
#define PII pair<int,int>
#define fi first
#define se second
#define endl '\n'
const int N=1e6+6;
int n,a[N],k;
void solve()
{
	cin>>n>>k;
	a[0]=k;
	int mx=-1e18;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
		mx=max(a[i]+a[i-1],mx);
	}
	mx=max(mx,k+a[n]);
	cout<<mx<<endl;
}
signed main()
{
	IOS;
	int _=1;
	cin>>_;
	while(_--)
	solve();
	return 0;
}

B-Card Game

解题思路

可以证明将大于小红最小牌的牌都放前面得分最多。我们只需要先算出小苯的牌中,大于小红的最小牌mi的数量m1,将大于mi的牌放在前面,有m1!种排列方式,剩下的小于mi的牌没有利用价值,放在后面,有(n-m1)!种排列方式,因此最终的组合方式就是二者之积。

代码实现

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define IOS ios::sync_with_stdio(0),cin.tie(0),cout.tie(0)
#define int long long
#define PII pair<int,int>
#define fi first
#define se second
#define endl '\n'
const int N=1e6+6;
const int mod=998244353;
int n,a[N],b[N],k;
int Jie(int x1,int x2)
{
	int s1=1,s2=1;
	for(int i=1;i<=x1;i++)
	{
		s1=(s1*i)%mod;
	}
	for(int i=1;i<=x2;i++)
	{
		s2=(s2*i)%mod;
	}
	if(x1==0)return s2;
	if(x2==0)return s1;
	return (s1*s2)%mod;
}
void solve()
{
	cin>>n;
	for(int i=1;i<=n;i++)cin>>a[i];
	int mi=1e18;
	for(int i=1;i<=n;i++)
	{
		cin>>b[i];
		mi=min(mi,b[i]);
	}
	int m1=0;//大于b中最小值的
	for(int i=1;i<=n;i++)
	{
		if(a[i]>mi)m1++;
	}
	int m2=n-m1;
//	cout<<m1<<" "<<m2<<endl;
	int ans=Jie(m1,m2);
	cout<<ans<<endl;
}
signed main()
{
	IOS;
	int _=1;
	cin>>_;
	while(_--)
	solve();
	return 0;
}
相关推荐
song8546011342 小时前
hash和history导航区别 个别服务器为啥不支持 history 模式
服务器·算法·哈希算法
IT猿手2 小时前
多无人机动态避障路径规划研究:基于粒子群优化算法PSO的多无人机动态避障路径规划研究(可以自定义无人机数量及起始点),MATLAB代码
算法·matlab·机器人·无人机·路径规划·动态路径规划
MoonBit月兔2 小时前
MoonBit 0.8.3版本更新
开发语言·人工智能·算法·ai编程·moonbit
xsyaaaan2 小时前
leetcode-hot100-哈希表:1两数之和-49字母异位词分组-128最长连续序列
算法·leetcode·散列表
代码探秘者2 小时前
【Redis】双写一致性:延迟双删 / 读写锁 / 异步通知 / Canal,一文全解
java·数据库·redis·后端·算法·缓存
郭逍遥2 小时前
[Godot] 沃罗诺伊图生成算法
算法·c#·游戏引擎·godot
还在忙碌的吴小二2 小时前
Mac 电脑安装qwen3.5:0.8b 有哪些方法
macos
像污秽一样2 小时前
算法设计与分析-算法效率分析基础-蛮力法
数据结构·算法·排序算法
Zhijun.li@Studio2 小时前
【2026 最新】Mac 上手 OpenCode 完整安装指南(火山豆包 + 自定义模型)
macos·大模型·opencode