1.14 日志(递推ybtoj)

明天要模拟,n年未碰电脑,先不学新的了。。。。

1.错排问题

dp最棒了
在这里插入图片描述
code:
#include
#include
#include
#include
#include
using namespace std;
const int M=INT_MAX;
long long f[25][25]={ };//f[i][j]表示有i个数,其中j个数可以随便填
int jc[22];
void solve(){
jc[1]=1;
for(int i=2;i<=20;i++){
jc[i]=jc[i-1] * i;
}

}
long long dp(int num,int a){
if(f[num][a]!=0) return f[num][a];
if(num==a) return jc[num];//都自由则转化为阶乘问题
long long res=0;
if(a!=0){
res += a * dp(num-1,a);
}//讨论不可自由填的那一位填什么
if(num>a+1){
res += (num-1-a) * dp(num-1,a+1);
}
f[num][a]=res;
return res;
}
int main(){
f[0][0]=1;
f[1][0]=0;
solve();//我这行一开始忘打了,结果调了半天。。。
int n;
scanf("%d",&n);
long long ans=dp(n,0);
printf("%lld",ans);
return 0;
}

2.奇怪的汉诺塔

在这里插入图片描述
与3塔的转换与取最小值是我没想到的。。。
#include
#include
#include
#include
#include
using namespace std;
const int M=INT_MAX;
int main(){
int f[15] = { };
int k[15] = { };
for(int i=1;i<=12;i++){
k[i]=M;
}
f[1]=1;
f[2]=3;
k[1]=1;
for(int i=3;i<=12;i++){
f[i] = 2 * f[i-1] + 1;
}
for(int i=2;i<=12;i++){
for(int j=1;j<=i;j++){
k[i] = min(k[i],2*k[j]+f[i-j]);
}
}
for(int i=1;i<=12;i++){
printf("%d\n",k[i]);
}
return 0;
}

数的划分

在这里插入图片描述
一遍AC针不戳(dp太香了)

#include
#include
#include
#include
#include
using namespace std;
const int M = INT_MAX;
int f[202][202][8] = {};
long long dp(int min, int left, int num) {
if (f[min][left][num] != 0)
return f[min][left][num];
if (num == 1)
return 1;
int res = 0;
for (int i = min; i <= left / num; i++) {
res += dp(i, left - i, num - 1);
}
return f[min][left][num] = res;
}
int main() {
int a, b;
scanf("%d%d", &a, &b);
printf("%lld", dp(1, a, b));
return 0;
}

4.传球游戏

在这里插入图片描述
一开始一直在讨论奇偶性和转圈上纠结。。。
#include
#include
#include
#include
#include
using namespace std;
const int M = INT_MAX;
int main() {
int m, n;
long long f[50][50];
scanf("%d%d", &n, &m);
f[0][1] = 1;
for (int i = 1; i <= m; i++) {
for (int j = 1; j <= n; j++) {
if (j == 1)
f[i][j] = f[i - 1][n] + f[i - 1][2];
else if (j == n)
f[i][j] = f[i - 1][n - 1] + f[i - 1][1];
else
f[i][j] = f[i - 1][j - 1] + f[i - 1][j + 1];
}
}
printf("%lld", f[m][1]);
return 0;
}

平铺方案

在这里插入图片描述
opj原题,直接水掉~~

#include
#include
#include
#include
using namespace std;
int ans[1001], x[300][1000];
int pus(int s1[], int s2[]) {
int i;
memset(ans, 0, sizeof(ans));
int l1 = 500;
while (s1[l1] == 0) l1–;
int l2 = 500;
while (s2[l2] == 0) l2–;
for (i = 0; i <= max(l1, l2); i++) {
ans[i] += s1[i] + s2[i];
if (ans[i] >= 10) {
ans[i] -= 10;
ans[i + 1] += 1;
}
}
int k = i + 5;
while (ans[k] == 0) k–;
return k;
}
void solve() {
for (int i = 0; i <= 300; i++) {
for (int j = 0; j <= 500; j++) {
x[i][j] = 0;
}
}
x[0][0] = 1;
x[1][0] = 1;
for (int i = 2; i <= 252; i++) {
if (i == 23) {
int o = 15;
}
if (i == 20) {
int l = 15;
}
int m = pus(x[i - 2], x[i - 1]);
for (int j = 0; j <= m; j++) {
x[i][j] = ans[j];
}
m = pus(x[i], x[i - 2]);
for (int j = 0; j <= m; j++) {
x[i][j] = ans[j];
}
}
}
int main() {
solve();
int p;
while (scanf("%d", &p) != EOF) {
int z = 500;
while (x[p][z] == 0) z–;
for (int i = z; i >= 0; i–) {
printf("%d", x[p][i]);
}
printf("\n");
}
return 0;
}

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

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

相关文章

平面分割 题解(1.16 递推模拟)

平面分割 代码一行&#xff0c;解析一箱~~ 解析 计f[i]&#xff1a;从1到i累加之和 先假设最好情况&#xff0c;p2&#xff1b; 此时第一条会增加1个 第二条与第一条相交&#xff0c;再加2个 第三条与前2条相交&#xff0c;再加3个 … 故n条时共增加f[n]个&#xff0c;共f[n]…

.NET Core实战项目之CMS 第二章 入门篇-快速入门ASP.NET Core看这篇就够了

本来这篇只是想简单介绍下ASP.NET Core MVC项目的&#xff08;毕竟要照顾到很多新手朋友&#xff09;&#xff0c;但是转念一想不如来点猛的&#xff08;考虑到急性子的朋友&#xff09;&#xff0c;让你通过本文的学习就能快速的入门ASP.NET Core。既然是快速入门所以过多过深…

题解: 区间合并(opj 2-4-7620)

一开始轻视这道题了&#xff0c;想用各种各样奇怪的区间标记把这道题水掉&#xff0c;结果WA声一片。。&#xff08;我大意了&#xff0c;没有AC&#xff01;&#xff09; 后来大脑开始思考&#xff0c;贪心解决掉了&#xff0c;AC快乐~~&#xff08;忽略这道题来自分治…qwq&a…

牛客题霸 [二叉搜索树的第k个结点]C++题解/答案

牛客题霸 [二叉搜索树的第k个结点]C题解/答案 题目&#xff1a; 给定一棵二叉搜索树&#xff0c;请找出其中的第k小的结点。 题解&#xff1a; 二叉搜索树&#xff1a; 若它的左子树不空&#xff0c;则左子树上所有结点的值均小于它的根结点的值; 若它的右子树不空&#xf…

内部设计师揭秘!王者峡谷中竟有隐藏的c++代码??!!腾讯已经炸了!!!

解析 模拟的时候用关于n的一元二次方程实根公式解的不亦乐乎。。。后来经高人提醒才发现万物皆为斐波拉契。。 就很《离谱》 于是代码就不难了 也算有收获吧&#xff0c;遇到这种看起来莫名其妙的题时&#xff0c;不着急死磕&#xff0c;可以先写个上图一样的程序找找规律 “实…

.NET Core实战项目之CMS 第三章 入门篇-源码解析配置文件及依赖注入

写在前面上篇文章我给大家讲解了ASP.NET Core的概念及为什么使用它&#xff0c;接着带着你一步一步的配置了.NET Core的开发环境并创建了一个ASP.NET Core的mvc项目&#xff0c;同时又通过一个实战教你如何在页面显示一个Content的列表。不知道你有没有跟着敲下代码&#xff0c…

对.NET Core未来发展趋势的浅层判断

经常听到园里.NET开发人员在抱怨生态不如JAVA&#xff0c;想要转JAVA&#xff0c;所谓打不过你&#xff0c;我就加入你&#xff01;杜兰特的思维方式固然是获取总冠军的一种方式&#xff0c;但是我们要关起门来问自己有没有杜兰特的实力。用开发生态来类比NBA不是特别恰当&…

2021牛客暑期多校训练营1 H-Hash Function(数学+FFT)

H-Hash Function Shining_xzl大佬题解 本题答案符合题意的充分必要条件是&#xff1a;不能是任意两个数的差以及他们的因数&#xff0c;因此只需用用FFT求出这些数的差&#xff0c;记为差的集合。 从小到大考虑一个答案&#xff0c;以及答案的倍数是不是上述差的集合&#x…

priority_queue+贪心:运输(题解)

解析 不难发现每次都应合并最大的一对&#xff0c;从而使局部最优带动整体最优 sort就会很自然的想到 但是问题是合并完之后的新值可能已经不是当前最大了&#xff08;WA。。qwq&#xff09; 于是想到每次循环sort一遍&#xff0c;结果n^2logn又超时了。。。 在一位高人的指引…

【话题揭秘】某大型国有银行的敏捷落地实践

“某大型国有银行的敏捷落地实践”话题介绍银行行业是强烈依赖IT的非IT行业&#xff0c;传统金融要想打破现有局面&#xff0c;除了要解决外因&#xff0c;还要突破内部因素&#xff0c;其中一点就是技术重塑和战略手段&#xff0c;也就是常说的数字化转型&#xff0c;这也是经…

震惊!温州一程序员编完八皇后吐血而亡,他的代码是什么样子?!!

解析 经典大法师&#xff08;dfs哈哈哈&#xff09; 比较关键的是每条对角线上点的坐标之和或差是相同的&#xff0c;故可以用一维数组存储其状态 这题一开始用了双层循环&#xff0c;卡掉了4个点qwq 后来发现其实因为每行只有一个皇后&#xff0c;每次单层循环枚举j就可以实…

直播视频发布:Windows上的Linux容器和Azure混合云中的Kubernetes(k8s)

如果你还没有开始关注容器&#xff0c;那么你已经out了&#xff1b;如果你还在单机上运行容器&#xff0c;那么你out了。经过2013到2018年5年的演化&#xff0c;分化和进化&#xff1b;容器&#xff0c;Docker和Kubernetes已经是任何一家企业的IT解决方案都不能忽视的重要趋势。…

通过Microsoft Learn进行学习以提升技能

通过 Microsoft Learn&#xff0c;可以免费而且轻松有趣地学习 Microsoft 技术。Microsoft Learn的与众不同借助 Microsoft Learn&#xff0c;任何人都能按自己的学习计划和速度掌握重要的知识和概念。 使用者将能够访问培训资料、代码示例&#xff0c;以及免费试用产品。无论是…

asp.net core webApi 参数保护

Introasp.net core data protection 扩展&#xff0c;基于 IDataProtector 扩展的数据保护组件&#xff0c;自动化的实现某些参数的保护ParamsProtectionParamsProtection 是为了保护 asp.net core webapi 项目的某些参数而设计的&#xff0c;也可以用来做一定程度上的反爬虫。…

2021牛客暑期多校训练营2 J-Product of GCDs(数论+计数)

J-Product of GCDs Code1 对于每个质数以及每个质数的次幂单独考虑他们的贡献&#xff0c;由于多次使用快速幂导致TLE #include<bits/stdc.h> using namespace std; using lllong long; template <class Tint> T rd() {T res0;T fg1;char chgetchar();while(!is…

新汉诺塔(洛谷P1242)含第11个数据的解决办法

解析 应该从大到小一个个移&#xff0c;这样后面大盘就可以直接忽略&#xff0c;保证没有冗余操作&#xff0c;必定最优&#xff08;如果先移动小的&#xff0c;后面移动大的时还要动小的&#xff09; 对于第id个从当前位置到目标的移动有两种移动方案&#xff1a; 法1&#x…

让 .Net 更方便的导入导出Excel

Intro因为前一段时间需要处理一些 excel 数据&#xff0c;主要是导入/导出操作&#xff0c;将 Excel 数据转化为对象再用程序进行处理和分析&#xff0c;没有找到比较满意的库&#xff0c;于是就自己造了一个轮子&#xff0c;屏蔽掉了 xlsx 与 xls 的差别&#xff0c;屏蔽了 Np…

P7115-[NOIP2020]移球游戏【构造】

正题 题目链接:https://www.luogu.com.cn/problem/P7115 题目大意 n1n1n1个柱子&#xff0c;前面nnn个上面各有mmm个球&#xff0c;球有nnn种颜色&#xff0c;每种mmm个。 你每次可以把一个柱子最上面的球放到另一个上面&#xff0c;要求在820000820000820000次内使得同种颜色…

无限序列 (ybtoj C.3)

解析 乍一看很蒙的题 首先&#xff0c;a-b1的个数可以等价于**&#xff08;1-b&#xff09;1的个数减去&#xff08;1-a-1&#xff09;1的个数** 分析之后发现&#xff0c;经过多次变换后&#xff1a; 长度 1的个数 1 1 2 1 3 2 5 3 8 5 … … 又是熟悉的斐波拉契。。。 但是我…

2021牛客暑期多校训练营2 L-WeChat Walk(分块)

L-WeChat Walk 每个大点记录一下邻接点的最大步数 每次修改的时候&#xff0c;枚举修改点的邻接的大点来更新 修改大点的时候直接判是不是比邻接点都大 代码抄的std好不容易才看懂~ Code1 #include<bits/stdc.h> using namespace std; template <class Tint> T…