【蓝桥杯备赛】Day15:递推与递归(倒计时23天)

题目1:题目 2335: 信息学奥赛一本通T1422-活动安排

设有n个活动的集合E={1,2,…,n},其中每个活动都要求使用同一资源,如演讲会场等,而在同一时间内只有一个活动能使用这一资源。每个活动i都有一个要求使用该资源的起始时间si和一个结束时间fi,且si<fi。如果选择了活动i,则它在半开时间区间[si,fi)内占用资源。若区间[si,fi)与区间[sj,fj)不相交,则称活动i与活动j是相容的。也就是说,当si≥fj或sj≥fi时,活动i与活动j相容。选择出由相互兼容的活动组成的最大集合。

输入格式

第1行一个整数n(n≤1000),接下来n行,每行两个整数si和fi。

输出格式

输出尽可能多的互相兼容的活动个数。

样例输入

4
1 3
4 6
2 5
1 7

样例输出

2

python代码

n=int(input())
t=[]
a=1#互相兼容的活动数量for i in range(n):t.append(input().split())
for i in range(n):for j in range(2):t[i][j]=int(t[i][j])
t.sort(key=lambda x:x[0],reverse=True)#按照活动开始的时间进行降序排列
for i in range(n-1):if t[i][0]==t[i+1][0]:if t[i][1]>t[i+1][1]:t[i][1],t[i+1][1]=t[i+1][1],t[i][1]#左端点相同,将结束时间晚的放在后面lastx=t[0][0]#最晚结束的活动的开始时间
for k in range(1,n):if t[k][1]<=lastx:#某一活动在它 开始之前结束lastx=t[k][0]a+=1
print(a)

知识点

  1. 先把活动开始的时间进行降序排列,之后若左端点相同,将结束时间晚的放在后面,指针首先指向最晚结束的活动的开始时间,若是某一个活动的结束时间在它之前,那么这两个活动兼容
  2. 另外一种思路:先把活动结束的时间进行升序排列,之后若左端点相同,将结束时间晚的放在后面,指针首先指向最早结束的活动的结束时间,若是某一个活动的开始时间在它之后,那么这两个活动兼容

题目2:P1002 [NOIP2002 普及组] 过河卒

棋盘上 A 点有一个过河卒,需要走到目标
B 点。卒行走的规则:可以向下、或者向右。同时在棋盘上 C 点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点。因此称之为“马拦过河卒”。

棋盘用坐标表示,
A 点 (0,0)、B 点 (n,m),同样马的位置坐标是需要给出的。

输入格式

一行四个正整数,分别表示 B 点坐标和马的坐标。

输出格式

一个整数,表示所有的路径条数。

样例输入

6 6 3 3

样例输出

6

python代码

x,y,n,m=map(int,input().split())
x+=1
y+=1
n+=1
m+=1#便于计算,索引值从1开始ma=[[0]*25 for _ in range(25) ]#马的位置
step=[[0]*25 for _ in range(25)]#坐标ma[n][m]=1
step[1][1]=1ma[n-2][m-1]=1#马能到达的位置
ma[n-2][m+1]=1
ma[n+2][m-1]=1
ma[n+2][m+1]=1
ma[n-1][m-2]=1
ma[n-1][m+2]=1
ma[n+1][m-2]=1
ma[n+1][m+2]=1for i in range(1,x+1):for j in range(1,y+1):if (i!=1 or j!=1) and(not ma[i][j]):step[i][j]=step[i-1][j]+step[i][j-1]
print(step[x][y])

知识点

  1. 二维列表的建立方式:最初我以为ma=[[0]*5]*5来建立的,后来运行的时候一直报错,才知道这种方法会指向列,对某一值修改会对整列进行修改,那么正确的创建方式为:
  2. ma=[[0]*5 for _ in range(5)]
  3. 找到正常情况下的递推公式:step[i][j]=step[i-1][j]+step[i][j-1](只能向右或向下)
  4. 最后 把非正常情况的点 去除

题目3:

你的程序将由操作数序列 1,2,…,n 经过操作可能得到的输出序列的总数。

输入格式

输入文件只含一个整数 𝑛

输出格式

输出文件只有一行,即可能输出序列的总数目

样例输入

3

样例输出

5

python代码

n=int(input())
ans=1
for i in range(1,n+1):ans=ans*(4*i-2)//(i+1)
print(f'{ans:d}')

知识点

  1. 卡特兰数
  2. 进出栈序列:n 个元素进栈序列为:1,2,3,4,…,n,则有多少种出栈序列?

结论:
C n = C n − 1 ∗ 4 ∗ n − 2 n + 1 C_{_{n}}=C_{_{n-1}}* \frac{4*n-2}{n+1} Cn=Cn1n+14n2

题目4:# [NOIP2001 普及组] 数的计算

题目描述

给出正整数 n n n,要求按如下方式构造数列:

  1. 只有一个数字 n n n 的数列是一个合法的数列。
  2. 在一个合法的数列的末尾加入一个正整数,但是这个正整数不能超过该数列最后一项的一半,可以得到一个新的合法数列。

请你求出,一共有多少个合法的数列。两个合法数列 a , b a, b a,b 不同当且仅当两数列长度不同或存在一个正整数 i ≤ ∣ a ∣ i \leq |a| ia,使得 a i ≠ b i a_i \neq b_i ai=bi

输入格式

输入只有一行一个整数,表示 n n n

输出格式

输出一行一个整数,表示合法的数列个数。

样例 #1

样例输入 #1

6

样例输出 #1

6

提示

样例 1 解释

满足条件的数列为:

  • 6 6 6
  • 6 , 1 6, 1 6,1
  • 6 , 2 6, 2 6,2
  • 6 , 3 6, 3 6,3
  • 6 , 2 , 1 6, 2, 1 6,2,1
  • 6 , 3 , 1 6, 3, 1 6,3,1

数据规模与约定

对于全部的测试点,保证 1 ≤ n ≤ 1 0 3 1 \leq n \leq 10^3 1n103

python代码

def count(n):global ansfor i in range(1,n+1):for j in range(1,int(i/2)+1):f[i]+=f[j]f[i]+=1n=int(input())
ans=1#自身
f=[0]*1001
if n==1:print(ans)
else:count(n)print(f[n])

知识点

  1. 先找规律,然后代码实现
  2. f(1)=1,f(2)=2,f(3)=2
  3. f(4)=f(1)+f(2)+1
  4. f(5)=f(1)+f(2)+1
  5. f(6)=f(1)+f(2)+f(3)+1
  6. f(7)=f(1)+f(2)+f(3)+1

题目5:# 黑白棋子的移动

题目描述

2 n 2n 2n 个棋子排成一行,开始为位置白子全部在左边,黑子全部在右边,如下图为 n = 5 n=5 n=5 的情况:

移动棋子的规则是:每次必须同时移动相邻的两个棋子,颜色不限,可以左移也可以右移到空位上去,但不能调换两个棋子的左右位置。每次移动必须跳过若干个棋子(不能平移),要求最后能移成黑白相间的一行棋子。如 n = 5 n=5 n=5 时,成为:

任务:编程打印出移动过程。

输入格式

一个整数 n n n

输出格式

若干行,表示初始状态和每次移动的状态,用 o \verb!o! o 表示白子, * \verb!*! * 表示黑子, - \verb!-! - 表示空行。

样例 #1

样例输入 #1

7

样例输出 #1

ooooooo*******--
oooooo--******o*
oooooo******--o*
ooooo--*****o*o*
ooooo*****--o*o*
oooo--****o*o*o*
oooo****--o*o*o*
ooo--***o*o*o*o*
ooo*o**--*o*o*o*
o--*o**oo*o*o*o*
o*o*o*--o*o*o*o*
--o*o*o*o*o*o*o*

python代码

def printx():#打印单元for i in range(2*n+2):print(c[i],end='')print()def move(n):if n==4:#n==4时,已经为最小问题,需要列举c[3],c[8]=c[8],c[3]c[4],c[9]=c[9],c[4]        printx()#打印第一步c[3],c[7]=c[7],c[3]c[4],c[8]=c[8],c[4]printx()#打印第二步c[1],c[7]=c[7],c[1]c[2],c[8]=c[8],c[2]printx()#打印第三步c[1],c[6]=c[6],c[1]c[2],c[7]=c[7],c[2]printx()#打印第四步c[0],c[6]=c[6],c[0]c[1],c[7]=c[7],c[1]printx()#打印第五步else:c[n-1],c[2*n]=c[2*n],c[n-1]c[n],c[2*n+1]=c[2*n+1],c[n]printx()c[n-1],c[2*n-2]=c[2*n-2],c[n-1]c[n],c[2*n-1]=c[2*n-1],c[n]printx()move(n-1)n=int(input())
c=[]#存放元素
for i in range(n):print('o',end='')c.append('o')for j in range(n,2*n):print('*',end='')c.append('*')
c.append('-')
c.append('-')#一共2n+2个值,索引到c[2n+1]
print('--')
move(n)

知识点

  1. 首先找规律,之后从最小的单元开始,即n=4,会发现n=5移动2步后就会变为n=4的问题,依次形成递归的思路
  2. 注意每一步调用printx()函数,对于未完全输出一行数据,end='',一行输出完毕,利用print()换行

题目6:# [NOIP1998 普及组] 幂次方

题目描述

任何一个正整数都可以用 2 2 2 的幂次方表示。例如 $137=27+23+2^0 $。

同时约定次方用括号来表示,即 a b a^b ab 可表示为 a ( b ) a(b) a(b)

由此可知, 137 137 137 可表示为 2 ( 7 ) + 2 ( 3 ) + 2 ( 0 ) 2(7)+2(3)+2(0) 2(7)+2(3)+2(0)

进一步:

7 = 2 2 + 2 + 2 0 7= 2^2+2+2^0 7=22+2+20 ( 2 1 2^1 21 2 2 2 表示),并且 3 = 2 + 2 0 3=2+2^0 3=2+20

所以最后 137 137 137 可表示为 2 ( 2 ( 2 ) + 2 + 2 ( 0 ) ) + 2 ( 2 + 2 ( 0 ) ) + 2 ( 0 ) 2(2(2)+2+2(0))+2(2+2(0))+2(0) 2(2(2)+2+2(0))+2(2+2(0))+2(0)

又如 1315 = 2 10 + 2 8 + 2 5 + 2 + 1 1315=2^{10} +2^8 +2^5 +2+1 1315=210+28+25+2+1

所以 1315 1315 1315 最后可表示为 2 ( 2 ( 2 + 2 ( 0 ) ) + 2 ) + 2 ( 2 ( 2 + 2 ( 0 ) ) ) + 2 ( 2 ( 2 ) + 2 ( 0 ) ) + 2 + 2 ( 0 ) 2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0) 2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

输入格式

一行一个正整数 n n n

输出格式

符合约定的 n n n 0 , 2 0, 2 0,2 表示(在表示中不能有空格)。

样例 #1

样例输入 #1

1315

样例输出 #1

2(2(2+2(0))+2)+2(2(2+2(0)))+2(2(2)+2(0))+2+2(0)

提示

【数据范围】

对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 2 × 10 4 1 \le n \le 2 \times {10}^4 1n2×104

python代码

def culi(n):m=0#记录幂if n==1:#最小问题print('2(0)',end='')elif n==2:print('2',end='')elif n>=3:while n>=a[m+1]:#找到最大的幂m+=1#print(m)n-=a[m]print('2',end='')if m>=2:print('(',end='')culi(m)print(')',end='')if n!=0:#子问题print('+',end='')culi(n)n=int(input())
a=[]
for i in range(16):a.append(pow(2,i))
culi(n)

知识点

  1. 数学分治+递归的思想,当n>=3,拆分成n=1n=2的问题
  2. 由于最大的数值不是很大(2^15),所以利用查表确定最大的索引值,之后进行两次递归。

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

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

相关文章

【C++】CC++内存管理

目录 一、C/C内存分布二 、C语言中动态内存管理方式&#xff1a;malloc/calloc/realloc/free三、 C内存管理方式3.1 new/delete操作内置类型3.2 new和delete操作自定义类型3.3 长度域 四、operator new与operator delete函数五、new和delete的实现原理5.1 内置类型5.2 自定义类…

【LAMMPS学习】三、构建LAMMPS(7)具有额外构建选项的软件包

3. 构建 LAMMPS 3.7.具有额外构建选项的软件包 当使用某些包进行构建时&#xff0c;除了Build_package页面上描述的步骤之外&#xff0c;可能还需要额外的步骤。 ​ 对于CMake构建&#xff0c;可能有额外的可选或必需的变量要设置。对于使用make进行构建&#xff0c;可能需…

【C语言】基本语法知识C语言函数操作符详解

主页&#xff1a;醋溜马桶圈-CSDN博客 专栏&#xff1a;C语言_醋溜马桶圈的博客-CSDN博客 gitee&#xff1a;mnxcc (mnxcc) - Gitee.com 目录 1.基本语法 1.1 代码解释 1.1.1 main()主函数 1.1.2 int 1.1.3 { } 1.1.4 printf()库函数 1.1.5 stdio.h头文件 1.2 C语言的…

[C语言]——操作符详解

目录 一.操作符的分类 二.二进制和进制转换 1.二进制转十进制 2.二进制转八进制和十六进制 2.1二进制转八进制 2.2二进制转十六进制 三.原码、反码、补码 四.移位操作符 1.左移操作符 2.右移操作符 五.位操作符&#xff1a;&、|、^、~ 练习1&#xff1a;编写代码实…

3d纸模型图纸制作方法---模大狮模型网

制作3D纸模型图纸通常需要按照以下步骤进行&#xff1a; 选择设计模型&#xff1a; 首先确定你想要制作的3D纸模型的设计&#xff0c;可以是建筑物、动物、交通工具等各种形式的模型。 绘制设计图纸&#xff1a; 使用计算机辅助设计软件(如AutoCAD、SketchUp)或手工绘图工具…

JavaMySQL高级一(下)

目录 1.常用函数 1.字符串函数 2.时间日期函数 3.聚合函数 4.数学函数 2.分布查询 3.子查询基础 1.简单子查询 1.常用函数 在程序开发过程中&#xff0c;除了简单的数据查询&#xff0c;还有基于已数据进行数据的统计分析计算等需求。因此&#xff0c;在SQL中将一…

数据库学习记录(二)多表设计与多表查询

一对多 一对多时候&#xff0c;一张表内的一个数据可能对应着其他表内的多个数据&#xff0c;例如一个部门内有多个员工&#xff0c;但是公司里不只一个部门&#xff0c;也不止一个员工&#xff0c;这个时候就是一对多的情况&#xff0c;这个时候可以绑定一个外键&#xff0c;…

Linux 磁盘的一生

注意&#xff1a;实验环境都是使用VMware模拟 ​ 磁盘接口类型这里vm中是SCSI&#xff0c;扩展sata,ide(有时间可以看看或者磁盘的历史) ​ 总结&#xff1a;磁盘从有到无—类似于建房子到可以住 ————————————————————————————————————…

php laravel 二维码

public function qr($url,$name2,$inpath){require_once(dirname(__FILE__) . /../../../Library/phpqrcode/phpqrcode.php);$errorCorrectionLevel L;//容错级别$matrixPointSize 10;//生成图片大小$QRcode new \QRcode() ;$QRcode->png($url, $inpath.$name2, $errorCor…

YOLOv5改进系列:Efficientrep结构助力涨点

一、论文理论 本文提出一种硬件友好的卷积神经网络结构,该结构类似于repvgg。在衡量网络效率时,经常使用Flops或者参数量,这些衡量指标对于硬件计算能力和内存带宽不敏感。因此,如何设计一个神经网络架构,使其有效地利用硬件计算能力和内存带宽是至关重要的。 论文地址:…

@Autowired详解

请直接看原文: Autowired注解详解——超详细易懂-CSDN博客 -------------------------------------------------------------------------------------------------------------------------------- Autowired详解 要搞明白Autowired注解就是要了解它是什么&#xff1f;有…

C++入门(下)

文章目录 1:引用1.1:引用概念1.2:引用的特性.1.2.1:引用在定义时必须初始化1.2.2:一个变量可以有多个引用1.2.3:引用一旦引用一个实体,再不能引用其他实体. 1.3:应用场景1.3.1:做参数1.3.2:做返回值1.3.2.1:传值返回1.3.2.2:传引用返回(错误示范)1.3.2.3:传引用返回(正确示范) …

如何在Ubuntu使用宝塔部署Emlog网站并发布到公网实现任意浏览器访问

文章目录 前言1. 网站搭建1.1 Emolog网页下载和安装1.2 网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar临时数据隧道2.2.Cpolar稳定隧道&#xff08;云端设置&#xff09;2.3.Cpolar稳定隧道&#xff08;本地设置&#xff09; 3. 公网访问测试总结 前言 博客作为使…

springboot Thymeleaf模版引擎使用

1.引入依赖 <!--thymeleaf视图引擎--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> html中要声明约束&#xff0c;这样就可以使用themelraf视…

探索 PostgreSQL 的外部数据包装器和统计函数

PostgreSQL 因其稳定性和可扩展性而广受青睐&#xff0c;为开发人员和数据管理员提供了许多有用的函数。在这些函数中&#xff0c;file_fdw_handler、file_fdw_validator、pg_stat_statements、pg_stat_statements_info 以及 pg_stat_statements_reset 是其中的重要函数&#x…

MySOL数据库管理

数据库基本操作 库和表 数据库–>数据表–>行&#xff08;记录&#xff09;&#xff1a;用来描述一个对象的信息列&#xff08;字段&#xff09;&#xff1a;用来描述对象的一个属性常用的数据类型 int整型float单精度浮点 4字节32位double双精度浮点 8字节64位char固…

3d模型变形动画怎么做---模大狮模型网

要制作3D模型的变形动画&#xff0c;你可以通过使用动画软件(如Blender、Maya、3ds Max等)中的变形工具和技术来实现。以下是一般的步骤来制作3D模型的变形动画&#xff1a; 创建基础模型&#xff1a;首先&#xff0c;在3D建模软件中创建或导入你想要进行变形的基础模型。这个基…

LeetCode 刷题 --- 快速幂

前言&#xff1a; 幂运算是一种常见的运算&#xff0c;求取a^n,最容易想到的方法便是通过循环逐个累乘&#xff0c;其复杂度为O(n)&#xff0c;这在很多时候是不够快的&#xff0c;所以我们需要一种算法来优化幂运算的过程。 快速幂&#xff0c;二进制取幂&#xff08;Binary…

JUC并发编程(五)

1、java内存模型 Java内存模型&#xff08;Java Memory Model&#xff0c;JMM&#xff09;是Java编程语言中用于处理并发编程的一组规则和规范。它定义了Java程序中多线程之间如何交互以及内存如何被共享和访问的规则。它定义了主内存&#xff0c;工作内存的抽象概念&#xff0…

一文让你简单了解跨境电商需要购买堡垒机的几大原因

随着互联网技术的快速发展&#xff0c;跨境电商蓬勃发展&#xff0c;但发展过程中网络安全问题日益凸显。因此不少跨境电商企业购买了堡垒机。这是为什么呢&#xff1f;一文让你简单了解跨境电商需要购买堡垒机的几大原因。 一文让你简单了解跨境电商需要购买堡垒机的几大原因 …