牛客小白月赛75题解

C 豆子

构造题

由构造公式知 第n级好豆子 = 第n-1级坏豆子^1

所以只需要构造一个豆子结构就行

第 i 级豆子 = 第 i 级豆子 第 i 级豆子 第 i 级豆子 第 i 级豆子 ^ 1 第i级豆子=\begin{aligned} 第i级豆子 && 第i级豆子 \\ 第i级豆子 && 第i级豆子 \verb|^| 1 \end{aligned} i级豆子=i级豆子i级豆子i级豆子i级豆子^1

预处理构造一下输出就行

#include<iostream>
using namespace std;
bool s[1100][1100];
bool d[6][6];
void init(int n)
{s[1][1] = 1;for(int i=2;i<=n;++i){int x = (1<<(i-2));for(int j=1;j<=x;++j)for(int k=1;k<=x;++k){s[j+x][k] = s[j][k];s[j][k+x] = s[j][k];s[j+x][k+x] = s[j][k]^1;}}for(int i=3;i<6;++i)for(int j=3;j<6;++j)d[i][j] = 1;
}
void print(int x,int y,int u)
{for(int i=0;i<6;++i){for(int j=1;j<=y;++j)for(int k=0;k<6;++k){if((s[x][j]^u^d[i][k]))cout<<"*";elsecout<<".";}cout<<endl;}
}
int main()
{int n;cin>>n;init(n);int d = (1<<(n-1));for(int i=1;i<=d;++i){print(i,d,n&1^1);}return 0;
}

D 矩阵

直接两层bfs就行

#include<bits/stdc++.h>
using namespace std;
int dp[1010][1010][2];
int dr[] = {-1,0,1,0,0,1,0,-1};
queue<vector<int>>q;
string arr[1010];
int n,m;
void bfs(int x,int y,char f)
{memset(dp,0x3f,sizeof(dp));   dp[x][y][f-'0'] = 0;q.push({x,y,f-'0'});while(!q.empty()){auto u = q.front();q.pop();for(int i=0;i<4;++i){int nx = u[0] + dr[i<<1];int ny = u[1] + dr[i<<1|1];int nf = u[2]^1;if(nx>=0 && nx<n && ny>=0 && ny<m){int cost = 1;if(arr[nx][ny]-'0' != nf)cost = 2;if(dp[nx][ny][nf]>dp[u[0]][u[1]][u[2]]+cost){q.push({nx,ny,nf});dp[nx][ny][nf]=dp[u[0]][u[1]][u[2]]+cost;}}}}}int main()
{cin>>n>>m;for(int i=0;i<n;++i)cin>>arr[i];bfs(0,0,arr[0][0]);cout<<min(dp[n-1][m-1][0],dp[n-1][m-1][1])<<endl;
}/*
dp大概率会卡这组数据
2 10
1111101010
0101011111
*/

E 数数

由于数字不大,直接dp

用dp[i][j]表示长度为i时前缀和为j的方案数,显然只有 i ∣ j i|j ij(j被i整除)时才存在方案数

可以推出

d p [ i ] [ j ] = { 0 , j m o d i ≠ 0 ∑ k = j − m j d p [ i − 1 ] [ k ] , j m o d i = 0 dp[i][j] =\begin{cases} \ \ \ \ 0\ & , j\ mod\ i \ne 0 \\ \sum\limits^{j}_{k = j-m}dp[i-1][k] &, j\ mod\ i=0 \end{cases} dp[i][j]=     0 k=jmjdp[i1][k],j mod i=0,j mod i=0

这么遍历一次复杂度为 O ( n m l n ( n m ) ) O(nmln(nm)) O(nmln(nm)),由于dp中有很多0,所以可以优化一下

∑ k = j − m j d p [ i − 1 ] [ k ] = ∑ k = j − m + 1 i − 1 j i − 1 d p [ i − 1 ] [ k ∗ ( i − 1 ) ] \sum\limits^{j}_{k = j-m}dp[i-1][k] = \sum \limits^{\frac{j}{i-1}}_{k=\frac{j-m+1}{i-1}}dp[i-1][k*(i-1)] k=jmjdp[i1][k]=k=i1jm+1i1jdp[i1][k(i1)]

那么复杂度就变成了 O ( n l n ( n m ) l n ( m ) ) O(nln(nm)ln(m)) O(nln(nm)ln(m))

#include<bits/stdc++.h>
using namespace std;
using ll = long long;
const ll mod = 1e9+7;ll dp[6000000];
int main()
{int n,m;cin>>n>>m;for(int j=1;j<=m;++j)dp[j] = 1;for(int i=2;i<=n;++i){for(int j=i*m;j>=i;j-=i){dp[j] = 0;for(int k = j/(i-1)*(i-1);k>=max(0,j-m);k-=i-1)dp[j] = (dp[j]+dp[k])%mod;}}int ans = 0;for(int i=n;i<=n*m;i+=n)ans = (ans+dp[i])%mod;cout<<ans<<endl;
} 

F 打牌

请添加图片描述
直接大力出奇迹,乱搞得了

通过阅读题目

而阿宁在手上有两张相同的牌,第三张不同的牌时,阿宁在相同的牌中等概率随机挑一张交给下家。其它情况阿宁也是等概率随机挑选。

分析会发现阿宁的行为是确定的。即如果此时没有人win,阿宁就会把手中最多的牌发出去。所以在没有剪枝的情况下复杂度应该为 O ( 4 n ) O(4^n) O(4n)

说实话这游戏想长时间不赢其实很难的,阿宁的操作保证在多轮操作后他手上至少会有两种手牌,所以说阿宁一直处于听牌的状态,“只要能拿到那张牌……”“不好意思,和!”,

然后考虑如果其中一个人有三张的情况,假设为aaa,另外两人就是bbc,ccb。如果aaa是阿宁上家,阿宁就赢了。

下家(A)为aaa的时候,此时

  • 阿宁:bbc

  • A:aaa

  • B: ccb

阿宁打b,A打a,如果B不打b就赢了,因此想要游戏继续下去就得打b,因此就变成

  • 阿宁:bbc

  • A:aab

  • B: cca

考虑大伙都有两张牌的情况,会发现b手上至少存在一张能让阿宁赢的牌,阿宁打出去的牌必然是a需要的牌,阿宁手上有的牌ab都有(都可以用反证法证明)。用字母表示当前情况

  • 阿宁:aab

  • A:bbc/cca

  • B: cca/bbc

第一种情况{aab,cca,bbc}:

只有一种打法能让游戏继续下去,那就是阿宁打出A,A打出c,B打出a,此时会变成{aab,abb,ccc}情况。根据上面的分析,此时阿宁必赢

第二种情况{aab,cca,bbc}:

阿宁打出a,B为了阿宁不赢得打出b,A为了B不赢得打出c,此时变成{bba,aac,ccb}变成了必赢态

分析了一大轮,就会发现,在有限步内必有人会赢,而且这个有限步甚至不会超过5步。

所以这题直接暴力dfs就完事了,甚至不用剪枝。乱搞就行了。

#include<bits/stdc++.h>
#define ll long long 
using namespace std;
const ll mod = 1e9+7;
ll sp[3][3];
ll now[3][3];
map<char,int>mp;
ll qpow(ll a,ll b)
{ll ret = 1;while(b){if(b&1) ret = ret*a%mod;a = a*a%mod;b>>=1;}return ret;
}
ll dfs(int n)
{for(int i=0;i<3;++i)if(sp[i][0]*sp[i][1]*sp[i][2])return i==0;if(!n)return 0;ll ret = 0;int mx = 0;if(sp[0][1]>sp[0][mx]) mx = 1;if(sp[0][2]>sp[0][mx]) mx = 2;for(int i=0;i<3;++i){if(!sp[1][i])continue;for(int j=0;j<3;++j){if(!sp[2][j])continue;ll p = 1ll*sp[1][i]*sp[2][j]*qpow(9,mod-2)%mod;sp[0][mx]--;sp[1][mx]++;sp[1][i]--;sp[2][i]++;sp[2][j]--;sp[0][j]++;ret = (ret+dfs(n-1)*p%mod)%mod;sp[0][mx]++;sp[1][mx]--;sp[1][i]++;sp[2][i]--;sp[2][j]++;sp[0][j]--;}}return ret;
}
int main()
{mp['w'] = 0;mp['i'] = 1;mp['n'] = 2;int n;cin>>n;for(int i=0;i<3;++i)for(int j=0;j<3;++j){char c;cin>>c;sp[i][mp[c]]++;}ll ans = dfs(n);cout<<ans<<endl;
}

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

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

相关文章

Nginx Linux设置开机自启动

使用如下命令 vi /lib/systemd/system/nginx.service 创建并编辑文件将以下代码黏贴至此文件中 [Unit] Descriptionnginx Afternetwork.target[Service] Typeforking TimeoutSec0 #防止启动超时 Userroot Grouproot criptionnacos Afternetwork.target[Service] Typeforking T…

操作系统—软链接和硬链接的介绍、实现、区别

一、前言 有时候我们希望给某个文件取个别名&#xff0c;那么在 Linux 中可以通过硬链接 和软链接的方式来实现&#xff0c;它们都是比较特殊的文件&#xff0c;但是实现方式也是不相同的。 首先简单介绍一下&#xff0c;Linux文件系统的索引节点&#xff08;inode) 索引节点…

习题-Java网络编程

目录 1.TCP-对象 2.UDP​​​​​​​​​​​​​​ 1.TCP-对象 利用TCP传输对象信息&#xff0c;需要对对象进行实例化 User类&#xff1a; package dh09.demo02;import java.io.Serializable;public class User implements Serializable {private String name;private St…

使用Postman+JMeter进行简单的接口测试

以前每次学习接口测试都是百度&#xff0c;查看相关人员的实战经验&#xff0c;没有结合自己公司项目接口真正具体情况。 这里简单分享一下公司项目Web平台的一个查询接口&#xff0c;我会使用2种工具Postman和JMeter如何对同一个接口做调试。 准备工作 首先&#xff0c;登录公…

对话思必驰:语音+AIGC的时代才刚刚开始

思必驰的价值在于开创了以语音技术为基础&#xff0c;打开了用人机交互解决方案构建软硬件智能化的崭新篇章。具象地说&#xff0c;它不仅是ChatBot&#xff0c;更像是“Jarvis”。 数科星球原创 作者丨苑晶 编辑丨大兔 2023年已过半&#xff0c;人工智能已成为全社会所关注…

不可用的ES节点重启后重新加入集群

如果一个之前不可用的ES节点重启后重新加入集群,而该节点上还有旧的数据,ES会做以下几件事: ES会发现node2上有旧的数据分片会将node2上的分片标记为不可分配(unassigned)会将node2上的分片数据与其他 Master eligible 节点上的 primary/replica 数据对比如果数据不一致,ES会:…

【精致生活】打造舒适家居环境的绝佳选择-API商品详细介绍

【精致生活】打造舒适家居环境的绝佳选择-API商品详细介绍 在追求舒适家居环境的道路上&#xff0c;我们时常需要借助一些高质量的产品来实现。而今天&#xff0c;我们要介绍的这款API商品&#xff0c;则是您打造精致生活的不二选择。 淘宝/天猫获得淘宝商品详情 API 返回值…

使用OpenCV DNN推理YOLOv5-CLS转换后的ONNX分类模型

YOLOv5是一种先进的目标检测算法&#xff0c;而YOLOv5-CLS则是YOLOv5的一个变种&#xff0c;专门用于图像分类任务。为了在实际应用中使用YOLOv5-CLS模型&#xff0c;我们需要将其转换为Open Neural Network Exchange (ONNX) 格式&#xff0c;并使用OpenCV DNN库来进行推理。 …

基于FME二开产品:NewGIS integration介绍

目录 前言 一、模板上传 二、模板在线运行 1.模板参数解析 2.模板运行 三、成果管理 总结 前言 爆肝两个月&#xff0c;我和我的团队终于打造出了一款能完美适配所有FME模板的在线模板管理平台&#xff0c;目前支持FME2021版本的所有模板的在线运行、管理。整体技术框架…

uni-app:常见组件view、text、icon

根据html&#xff1a;可知div是块级标签&#xff0c;span是行级标签 这里view类似于div&#xff0c;text类似于span&#xff0c;即 块级标签&#xff1a;view 行级标签&#xff1a;text、icon 类似效果 两个icon图标&#xff0c;置于第一排 两个view&#xff0c;分别位于第…

matlab程序调试方法步骤

1内容 1&#xff09;代码内调试&#xff1b; 2&#xff09;断点调试方法&#xff1b; 3&#xff09;指令调试方法&#xff1b; 二、断点调试方法 调试代码最经典的就是利用设置断点的方法&#xff0c;此处给出对应快捷键&#xff1a; F12&#xff1a;设置/取消 断点 F10&…

项目名称:无源在线词典项目

一&#xff0c;概述 基于C语言的网络电子词典项目&#xff0c;使用到了tcp协议的并发服务器设计、网络编程、文件I/O、数据库等多方面的知识。可以满足多用户同时登陆&#xff0c;用户登陆后可以查询单词及历史记录&#xff0c;具有查找快速&#xff0c;保密性好等优点。 开…

JAVA集成国密SM4

JAVA集成国密SM4加解密 一、pom配置二、代码集成2.1、目录结构2.2、源码2.3、测试 三、遇到的坑3.1、秘钥长度3.2、转码问题 四、相关链接 国密算法概述&#xff1a;https://blog.csdn.net/qq_38254635/article/details/131801527 SM4对称算法 SM4 无线局域网标准的分组数据算…

wordpress 分类名称与链接

1.分类名称与链接 <?php the_category(); ?> 2.分类页面调用当前分类名称 要在分类页得到分类页面的栏目名称,需要用 <?php single_cat_title(); ?> 3.文章页调用当前文章所属分类名称 代码1 <?phpforeach((get_the_category()) as $category){echo $c…

添加资源到android源码中-修改framework层

编译带有资源的jar包&#xff0c;需要更改frameworks层&#xff0c;方法如下&#xff1a; 一.增加png类型的图片资源 1.将appupdate模块所有用到的png格式图片拷贝到framework/base/core/res/res/drawable-mdpi里。但是要确保没有与原生的没有重名文件。 2.在framework/base…

c++内存映射文件

概念 将一个文件直接映射到进程的进程空间中&#xff08;“映射”就是建立一种对应关系,这里指硬盘上文件的位置与进程逻辑地址空间中一块相同区域之间一 一对应,这种关系纯属是逻辑上的概念&#xff0c;物理上是不存在的&#xff09;&#xff0c;这样可以通过内存指针用读写内…

qt 32位编译 内存溢出 无法 运行在win7 32位

项目在 编译32位系统 内存溢出 设置成了x64 但是 最后在xp32位系统运行提示 在下载了n个dll之后发现这种状况无穷无尽&#xff0c;后来在查阅资料时发现可以直接打开qt安装目录下的“vcredist”文件夹&#xff0c;将对应位数的程序拷到win7电脑上&#xff0c;直接运行&…

Orleans 微软基于 Actor 的分布式框架

一、Actor模型工作原理 Actor模型是一种并发编程模型&#xff0c;它基于消息传递实现&#xff0c;是一种轻量级的并发模型。在Actor模型中&#xff0c;每个Actor都是一个独立的执行单元&#xff0c;它可以接收和发送消息&#xff0c;并且可以执行一些本地操作&#xff0c;但是不…

【ARM Cortex-M 系列 1 -- Cortex-M0, M3, M4, M7, M33 差异】

文章目录 Cortex-M 系列介绍Cortex-M0/M0 介绍Cortex-M3/M4 介绍Cortex-M7 介绍Cotex-M33 介绍 下篇文章&#xff1a;ARM Cortex-M 系列 2 – CPU 之 Cortex-M7 介绍 Cortex-M 系列介绍 Cortex-M0/M0 介绍 Cortex-M0 是 ARM 公司推出的一款微控制器&#xff08;MCU&#xff0…

网络安全在2023好入行吗?

前言 023年的今天&#xff0c;慎重进入网安行业吧&#xff0c;目前来说信息安全方向的就业对于学历的容忍度比软件开发要大得多&#xff0c;还有很多高中被挖过来的大佬。 理由很简单&#xff0c;目前来说&#xff0c;信息安全的圈子人少&#xff0c;985、211院校很多都才建…