【蓝桥杯备赛】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]=1


ma[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]=1

for 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 ans
    for i in range(1,n+1):
        for j in range(1,int(i/2)+1):
            f[i]+=f[j]
        f[i]+=1
    
n=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),所以利用查表确定最大的索引值,之后进行两次递归。

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

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

相关文章

管易云·奇门对接打通金蝶云星空发货单查询接口与销售出库新增接口

管易云奇门对接打通金蝶云星空发货单查询接口与销售出库新增接口 ​​ ​​ 对接源平台:管易云奇门 管易云是上海管易云计算软件有限公司旗下的专注提供电商企业管理软件服务的品牌&#xff0c;总部位于中国上海张江高科技产业园区。管易云旗下拥有管易云C-ERP、EC-OMS、EC-W…

HarmonyOS卡片刷新服务,信息实时更新一目了然

如今衣食住行娱乐影音等App占据了大多数人的手机&#xff0c;一部手机可以满足日常大多需求&#xff0c;但对需要经常查看或进行简单操作的场景来说&#xff0c;总需要用户点开App操作未免过于繁琐。 针对该问题&#xff0c; HarmonyOS SDK为用户提供了Form Kit&#xff08;卡…

为啥很多人觉得编程难学?

看到推特上网友菜脯写的一条推文&#xff1a; 菜脯&#xff1a;我大概知道&#xff0c;为啥很多人觉得编程难学了。 因为对我来说&#xff0c;编程过程就是 看资料——开始写——遇到问题——查资料——解决问题——继续写——继续遇问题——继续查资料… 这个循环似乎会一直持…

Retrieval Augmented Thoughts(RAT):检索增强思维,实现长视野生成中的上下文感知推理

论文地址&#xff1a;https://arxiv.org/pdf/2403.05313.pdf 原文地址&#xff1a;rat-retrieval-augmented-thoughts Github&#xff1a;Implementation of RAT 2024 年 3 月 14 日 介绍 让我首先从一些一般性观察开始...... 在生成式人工智能应用程序中实现效率与生成响应…

vulhub中Apache Shiro 认证绕过漏洞复现(CVE-2010-3863)

Apache Shiro是一款开源安全框架&#xff0c;提供身份验证、授权、密码学和会话管理。Shiro框架直观、易用&#xff0c;同时也能提供健壮的安全性。 在Apache Shiro 1.1.0以前的版本中&#xff0c;shiro 进行权限验证前未对url 做标准化处理&#xff0c;攻击者可以构造/、//、…

YOLOV9训练自己的数据集

1.代码下载地址GitHub - WongKinYiu/yolov9: Implementation of paper - YOLOv9: Learning What You Want to Learn Using Programmable Gradient Information 2.准备自己的数据集 这里数据集我以SAR数据集为例 具体的下载链接如下所示&#xff1a; 链接&#xff1a;https:/…

广州市高质量发展大会,东纺企服系统提出数智化新思路

近日&#xff0c;广州市海珠区凤阳街道高质量发展大会暨企业联盟沙龙荟在海珠区珠江国际纺织城D区6楼时尚馆召开。东纺科技作为海珠区企业代表&#xff0c;受邀出席参与活动。 本次大会对今年的高质量发展进行亮诺和展望。海珠区委常委、区纪委书记、区监委主任杨清谦以及海珠区…

【环境搭建和安装】thingsboard二次开发环境搭建

文章目录 1.安装JAVA2.安装maven环境3.安装nodeJS4.安装git环境5.安装npm依赖关系 提示&#xff1a; 1.我自己下载存放路径比较混乱&#xff0c;下载的文件尽量在一个新建的文件夹存放&#xff0c;目录全英更好。 2.环境是为了开源物联网平台&#xff0c;环境搭建和安装部署是成…

ETH网络 之 Gas花费实例

求关注&#xff0c;关注我&#xff0c;一起进入Web3的世界 前文回顾 GasBaseFee & PriorityFee部署ERC-721 交易Gas解析 部署NFT的交易 钱包Gas解读 费用清单 ItemValueDesc基础费用(BaseFee)0.102349622 Gwei基础费用是动态的&#xff0c;我们发送交易时是不确定的&…

想进阿里?先了解这个!@SpringMybatis注解面试解析

如有疑问或者更多的技术分享,欢迎关注我的微信公众号“知其然亦知其所以然”! 嗨,大家好!我是小米,今天要和大家聊一聊阿里巴巴面试题中的一个热门话题:@SpringMybatis注解。如果你是一个对技术充满好奇心的小伙伴,那么这篇文章一定会给你带来不少启发和收获! 在开始…

1、编写jsp文件,熟悉jsp页面的基本结构H编写看电影2、编写jsp文件,熟悉jsp动作标记、param传值的使用,计算机三角形的面积。

1、看电影 watchMovie.jsp: <% page language"java" contentType"text/html; charsetUTF-8" pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"UTF-8"> <title>Insert ti…

数据分析能力模型分析与展示

具体内容&#xff1a; 专业素质 专业素质-01 数据处理 能力定义•能通过各种数据处理工具及数据处理方法&#xff0c;对内外部海量数据进行清洗和运用&#xff0c;提供统一数据标准&#xff0c;为业务分析做好数据支持工作。 L1•掌握一…

41 物体检测和目标检测数据集【李沐动手学深度学习v2课程笔记】

目录 1. 物体检测 2. 边缘框实现 3.数据集 4. 小结 1. 物体检测 2. 边缘框实现 %matplotlib inline import torch from d2l import torch as d2ld2l.set_figsize() img d2l.plt.imread(../img/catdog.jpg) d2l.plt.imshow(img);#save def box_corner_to_center(boxes):&q…

小白向软件开发教学实战:企业培训APP的设计与开发

随着信息技术的迅猛发展&#xff0c;软件开发已经成为了一个日益重要的技能。无论是个人还是企业&#xff0c;都希望能够掌握一定的软件开发能力&#xff0c;以满足自身的需求。尤其是在企业培训领域&#xff0c;定制化的软件应用能够提高培训效率和质量。 一、需求分析 在设计…

Vue.js前端开发零基础教学(二)

目录 前言 2.1 单文件组件 2.2 数据绑定 2.2.2 响应式数据绑定 2.3 指令 2.3.1 内容渲染指令 2.3.2 属性绑定指令 ​编辑 2.3.3 事件绑定指令 2.3.4 双向数据绑定指令 2.3.5 条件渲染指令 2.3.6 列表渲染指令 2.4 事件对象 2.5 事件修饰符 学习目标&am…

#Linux(帮助手册)

&#xff08;一&#xff09;发行版&#xff1a;Ubuntu16.04.7 &#xff08;二&#xff09;记录&#xff1a; &#xff08;1&#xff09;键入命令man man查看手册目录&#xff08;按q退出&#xff09; &#xff08;2&#xff09;查看手册需要先安装依赖包&#xff08;root权限安…

【spring】@ConditionalOnResource注解学习

ConditionalOnResource 介绍 ConditionalOnResource 是Spring框架中的一个条件化注解&#xff0c;它允许你根据类路径中是否存在指定的资源来决定是否加载特定的Bean定义或配置类。这个注解可以用于类级别或方法级别。 具体Conditional使用请看这篇文章【spring】Conditional…

【漏洞复现】4. Gitlab exiftool远程命令执行漏洞(CVE-2021-22205)复现与分析

文章目录 1. 预备知识2. 漏洞复现2.1 漏洞介绍2.1.1 简介2.1.2 事件过程 2.2 漏洞原理分析2.3 漏洞复现2.3.1 靶场搭建2.3.2 漏洞测试2.3.3 漏洞利用2.3.4 POC分析 2.4 漏洞修复 1. 预备知识 GitLab是一个基于Web的Git仓库管理工具&#xff0c;它提供了完整的DevOps平台&#x…

通俗理解自注意力机制

自注意力机制&#xff08;Self-Attention Mechanism&#xff09; 是一种用于处理序列数据的机制&#xff0c;最初被引入到神经网络模型中&#xff0c;用于在序列数据中建立全局依赖关系。自注意力机制最常用于自然语言处理和计算机视觉领域&#xff0c;特别是在Transformer模型…

机器学习 - 预测训练模型

接着上篇博客机器学习-训练模型做进一步说明。 There are three things to make predictions (also called performing inference) with a PyTorch model: Set the model in evaluation mode (model.eval())Make the predictions using the inference mode context manager (…