牛客小白月赛97 (个人题解)(待补完)

前言:

  前天晚上写的一场牛客上比赛,虽然只写出了三道,但比起之前的成绩感觉自己明显有了一点进步了,继续努力吧,

正文:

 链接:牛客小白月赛97_ACM/NOI/CSP/CCPC/ICPC算法编程高难度练习赛_牛客竞赛OJ (nowcoder.com)

A 三角形:

#include<bits/stdc++.h>
using namespace std;
int a[100005];
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	}
	sort(a+1,a+n+1);
	int flag=0;
	for(int i=1;i<=n-2;i++){
		if(a[i]==a[i+1]&&a[i+1]==a[i+2])flag=1;
	}
	if(flag)cout<<"YES"<<endl;
	else cout<<"NO"<<endl;
	return 0;
}

签到题,我是排序后看看有没有三个连续相等的数字。更好的做法应该是用桶排看看有没有出现次数超过三的数字,其实都差不多。

B 好数组:

#include <bits/stdc++.h>
using namespace std;

int main()
{
    int n,x,f=1,a=0;cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>x;
        if(x==0) f=0;
    }
    if(f==0) cout<<"NO"<<endl;
    else cout<<"YES"<<endl;
    return 0;
}

又一道签到题,只要包含0就不是好数组。

C 前缀平方和序列:

#include<bits/stdc++.h>
using namespace std;
int n,x;
const long long mod=1e9+7;
typedef long long ll;
ll quick(ll a,ll b){
	ll res=1;
	while(b){
		if(b%2)res=res*a%mod;
		a=a*a%mod;
		b/=2;
	}
	return res;
}
ll f[10005];
void init(){
	f[0]=1;
	for(int i=1;i<=10005;i++){
		f[i]=f[i-1]*i%mod;
	}
}
ll inv(ll x){
	return quick(x,mod-2)%mod;
}
int main(){
	init();
	cin>>n>>x;
	ll cnt=(ll)sqrt(x);
    if(cnt<n){
        cout<<0<<endl;
        return 0;
    }
	//cout<<f[cnt]<<" "<<inv(f[n])<<" "<<inv(f[cnt-n])<<endl;
	ll ans=(f[cnt]*((inv(f[n])%mod*inv(f[cnt-n]%mod))%mod))%mod;
	cout<<ans<<endl;
	return 0;
}

预处理阶乘和逆元(费马小定理),然后求组合数,注意要开long long,并且在计算过程中一定要时时取模否则会暴。

D 走一个大整数迷宫:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
int a[15][15],b[15][15];
bool book[15][15][10005];
ll n,m,p;
ll quick(ll a,ll b,ll mod){
	ll res=1;
	while(b){
		if(b%2)res=res*a%mod;
		a=a*a%mod;
		b/=2;
	}
	return res;
}
int ne[4][2]={{0,-1},{0,1},{1,0},{-1,0}};
typedef struct stu{
	int x;
	int y;
	int z;
	int c;
}node;
int ans=1e9+7;
queue<node> q;
void bfs(int x,int y,int z,int c){
	node k={x,y,z,c};
	q.push(k);
	while(!q.empty()){
		k=q.front();
		q.pop();
		if(book[k.x][k.y][k.c%(p-1)])continue;
		book[k.x][k.y][k.c%(p-1)]=true;	
		if(k.x==n&&k.y==m&&k.c%(p-1)==0){
			ans=min(k.z,ans);
			break;
		}
		for(int i=0;i<4;i++){
			int nx=k.x+ne[i][0];
			int ny=k.y+ne[i][1];
			if(nx>=1&&nx<=n&&ny>=1&&ny<=m){
				//cout<<nx<<" "<<ny<<" "<<k.z+1<<" "<<k.c+a[nx][ny]<<endl;
                int cc=(k.c+a[nx][ny])%(p-1);
				node l={nx,ny,k.z+1,cc};
				q.push(l);
			}
		}
	}
}
int main(){
	cin>>n>>m>>p;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin>>a[i][j];
		}
	}
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			cin>>b[i][j];
		}
	}
	bfs(1,1,0,a[1][1]);
	if(ans==1e9+7)cout<<-1;
	else cout<<ans;
	return 0;
}

首先咱们先看c的表式方式

首先我们要知道我们最后要求的数是对(p-1)取模的数,我们完全可以在输入的时候就将图上的数直接取模。然后我们再对Cij进行简化,很容易发现p^{2^{bij}}对(p-1)取模一直都为1。

(由于p^{2^{bij}}=(p-1+1)^{2^{bij}}

可以将p^{2^{bij}}展开为1+x_{1}(p-1)^{1}+x_{2}(p-1)^{2}+...+x_{n}(p-1)^{n}

然后用bfs跑分层图,第一、二维为x,y,第三维为走到这个点时的计数器上的数对(p-1)取模的结果(这样能避免多走但计数器取模后一样的情况)。具体写法见上。如果能搜到答案就输出,不然就输出-1.

E 前缀和前缀最大值:

#include<bits/stdc++.h>
using namespace std;
int a[100005];
int pre[100005],sum[100005][101];
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		if(a[i]<0)pre[i]=pre[i-1]-a[i];
		else pre[i]=pre[i-1];
		for(int j=1;j<=100;j++){
			sum[i][j]=sum[i-1][j]+(a[i]==j);
		}
	}
	int q;
	cin>>q;
	for(int i=1;i<=q;i++){
		int l,r,tmp=0;
		cin>>l>>r;
		int t=pre[r]-pre[l-1];
		int res=0;
		int cnt=0;
		for(int j=1;j<=100;j++){
			int k=sum[r][j]-sum[l-1][j];
			if(k!=0){
				if(k*j+res>=t){
					cnt+=(t-res)/j;
					break;
				}
				else cnt+=k;res+=k*j;
                //cout<<" "<<t<<" "<<cnt<<" "<<res<<endl;
			}
		}
		cout<<cnt+1<<endl;
	}
	return 0;
}

这题是我看了他发的答案才写出来的,咱们首先得要知道他的A类价值数是连续的,可能又相等的值,但一定是一个区间内的所有数,考虑 A 类价值最小的方案,是从小到大排序序列 a。然后进行n 次,将序列 a 的最后一个数字移动到最前面。会发现这样操作序列 a 的 A 类价值是单调不减的,并且每次只移动一个数,增量只可能是0 或者 1。所以可以得出一个结论,A 类价值是连续的。所以我们最后只需要求他的最大A的值r和最小A值l,答案就为r-l+1。上界即为正数个数,下界就是从小到大排的第一个正数前缀到尾的距离。

F parent 树上启发式合并(待补):

看着好高级。

后记:

  我还是太菜了。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

短信接口API的选择因素?有哪些使用方法?

短信接口API的集成难点是什么&#xff1f;如何保障API安全性&#xff1f; 短信接口API已经成为许多企业和开发者的关键工具&#xff0c;市场上有许多不同的短信接口API可供选择&#xff0c;这使得选择适合的API变得尤为重要。AoKSend将探讨在选择短信接口API时需要考虑的主要因…

vscode的一些使用问题

vscode使用技巧 1、快捷键&#xff08;1&#xff09;打开命令面板&#xff08;2&#xff09;注释&#xff08;3&#xff09;删除行&#xff08;4&#xff09;上下移动光标&#xff08;5&#xff09;光标回退&#xff08;6&#xff09;复制行&#xff08;7&#xff09;插入空白行…

联邦的基础配置

一、联邦的定义 联邦&#xff1a;在AS内部部署全互联的IBGP对等体可以很好解决IBGP路由传递的问题&#xff0c;但是扩展性低&#xff0c;大型网络中会带来沉重负担&#xff0c;针对此问题可以用路由反射器解决&#xff0c;也可以利用联邦解决&#xff0c;联邦也被称为联盟。大…

干货分享:Spring中经常使用的工具类(提示开发效率)

环境&#xff1a;Spring5.3…30 1、资源工具类 ResourceUtils将资源位置解析为文件系统中的文件的实用方法。 读取classpath下文件 File file ResourceUtils.getFile(ResourceUtils.CLASSPATH_URL_PREFIX "logback.xml") ; // ...读取文件系统文件 file Resou…

ABAP 新语法-ITAB[ idx ]、ITAB[ key ]

这段ABAP代码主要演示了使用新的ABAP语法内表表达式的用法&#xff0c;其中核心点如下&#xff1a; 索引和关键字读取&#xff1a; 使用gt_student[1]进行索引读取&#xff0c;获取内表的第一个元素。使用gt_student[id 0000000005 age 15]进行关键字读取&#xff0c;根据指…

电子战学习笔记01:电子战概论

0、写在文前 本人在学习电子战相关理论知识时&#xff0c;一直感觉无从下手&#xff0c;之后在老师的推荐下购买了《EW101&#xff1a;电子战基础》纸质书籍学习&#xff0c;所以将自己的学习笔记在CSDN上记录一下&#xff0c;也供有需要的同学参考。 1、电子战定义 电子战&…

惠海100V 15A HC070N10L TO-252封装 N沟道MOS管 打火机/BMS电源板应用

MOS管的工作原理是基于在P型半导体与N型半导体之间形成的PN结&#xff0c;通过改变栅极电压来调整沟道内载流子的数量&#xff0c;从而改变沟道电阻和源极与漏极之间的电流大小。由于MOS管具有输入电阻高、噪声小、功耗低等优点&#xff0c;它们在大规模和超大规模集成电路中得…

ESP32-C3(基本信息)

ESP32-C3 是一款低功耗、高集成度的 MCU 系统级芯片 (SoC)&#xff0c;它集成了 2.4 GHz Wi-Fi 和低功耗蓝牙 (Bluetooth LE) 无线通信功能&#xff0c;并拥有丰富的外设接口和先进的电源管理机制。 主要特性&#xff1a; 无线通信&#xff1a; 支持 2.4 GHz Wi-Fi (802.11b/…

AI音乐革命:创新的门槛降低与产业未来的挑战

文章目录 每日一句正能量前言整体介绍人机合作AI在音乐创作中的辅助作用人机共同创作的模式实现人机共同创作的可能性伦理和法律考量 伦理道德AI与人类创造力的关系技术发展与人类创造力的平衡社会和文化影响结论 后记AI与音乐的未来交响创新的双刃剑版权与伦理的探讨人机合作的…

GaussDB关键技术原理:高性能(三)

GaussDB关键技术原理&#xff1a;高性能&#xff08;二&#xff09;从查询处理综述对GaussDB的高性能技术进行了解读&#xff0c;本篇将从查询重写RBO、物理优化CBO、分布式优化器、布式执行框架、轻量全局事务管理GTM-lite等五方面对高性能关键技术进行分享。 目录 3 高性能…

深入理解Java核心技术模块化局部变量类型推断

本人详解 作者:王文峰,参加过 CSDN 2020年度博客之星,《Java王大师王天师》 公众号:JAVA开发王大师,专注于天道酬勤的 Java 开发问题中国国学、传统文化和代码爱好者的程序人生,期待你的关注和支持!本人外号:神秘小峯 山峯 转载说明:务必注明来源(注明:作者:王文峰…

【C语言】23.文件操作

由于要对数据进行持久化保存&#xff0c;我们就有了文件。 一、程序文件与数据文件 磁盘&#xff08;硬盘&#xff09;上的文件是文件。 但是在程序设计中&#xff0c;我们⼀般谈的文件有两种&#xff1a;程序文件、数据文件&#xff08;从文件功能的角度来分类的&#xff09…

pdf压缩,pdf压缩在线网页版,在线压缩pdf网站

在数字化时代&#xff0c;pdf文件已经成为我们工作、学习和生活中不可或缺的一部分。然而&#xff0c;pdf文件往往体积庞大&#xff0c;传输效率低下&#xff0c;还占用大量存储空间。如何在不影响文件质量的前提下&#xff0c;减小pdf文件的大小呢&#xff1f;今天&#xff0c…

线程安全问题(二)——死锁

死锁 前言可重入锁逻辑 两个线程两把锁&#xff08;死锁&#xff09;死锁的特点多个线程多把锁&#xff08;哲学家就餐问题&#xff09;总结 前言 在前面的文章中&#xff0c;介绍了锁的基本使用方式——锁 在上一篇文章中&#xff0c;通过synchronized关键字进行加锁操作&am…

在Stimulsoft 报告中连接来自 MySQL 的数据

Stimulsoft Ultimate &#xff08;原Stimulsoft Reports.Ultimate&#xff09;是用于创建报表和仪表板的通用工具集。该产品包括用于WinForms、ASP.NET、.NET Core、JavaScript、WPF、PHP、Java和其他环境的完整工具集。无需比较产品功能&#xff0c;Stimulsoft Ultimate包含了…

数据结构(Java):迭代器遍历【底层源码解析】

1、引言 我们知道&#xff0c;对于List系列集合&#xff0c;添加的元素是有序、可重复、有索引的&#xff1b;而对于Set系列集合&#xff0c;添加的元素是无序、不重复、无索引的。 那么使用for循环通过下标来对Set系列集合进行遍历&#xff0c;那显然是不行的。 迭代器就可…

docker k8s

1、docker是什么&#xff1f; 将环境和程序一起打包给到 服务器运行的工具软件。 2、基础镜像base image是什么&#xff1f; 操作系统&#xff1a;用户空间、内核空间 阉割操作系统&#xff0c;利用其的用户空间&#xff08;因为应用程序运行在用户空间&#xff09;&#xf…

转换Python2 转 Python3 小程序

转换Python2 -> Python3 藉由python35\Tools\scripts\2to3.py 档转换 python D:\python\Tools\scripts\2to3.py D:\Users\a0979\Desktop\scrip.pypython [转档程式] [欲转档.py] * python 为 python3 ->因为转档程式为python3 ![](https://i.imgur.com/PeQkvhk.png)py…

STM32的EXTI简介

一&#xff0c;EXTI&#xff08;External Interrupt&#xff09;外部中断事件控制器 什么是EXTI&#xff1f; 1.监测指定的GPIO口的电平信号变化&#xff0c;并检测到指定条件时&#xff0c;向内核的中断控制器NVIC发出中断申请。NVIC在裁决后&#xff0c;如果满足条件&#xf…

工业4.0能给电能表带来什么机会

一、技术革新与升级 工业4.0的核心在于智能化和网络化&#xff0c;这促使电能表行业进行技术革新和升级。传统的电能表功能单一&#xff0c;主要用于测量电能消耗。而在工业4.0的推动下&#xff0c;电能表逐渐发展成为集信息储存和处理、网络通信、实时监测等多种功能于一体的…