CSDN每日一题学习训练——Python版(N皇后 II、买卖股票的最佳时机 II、编程通过键盘输入每一位运动员)
版本说明
当前版本号[20231120]。
| 版本 | 修改说明 |
|---|---|
| 20231120 | 初版 |
目录
文章目录
- 版本说明
- 目录
- N皇后 II
- 题目
- 解题思路
- 代码思路
- 参考代码
- 买卖股票的最佳时机 II
- 题目
- 解题思路
- 代码思路
- 参考代码
- 编程通过键盘输入每一位运动员
- 题目
- 解题思路
- 代码思路
- 参考代码
N皇后 II
题目
n 皇后问题 研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。
给你一个整数 n ,返回 n 皇后问题 不同的解决方案的数量。
示例 1:

输入:n = 4
输出:2
解释:如上图所示,4 皇后问题存在两个不同的解法。
示例 2:
输入:n = 1
输出:1
提示:
1 <= n <= 9
皇后彼此不能相互攻击,也就是说:任何两个皇后都不能处于同一条横行、纵行或斜线上。
以下程序实现了这一功能,请你填补空白处内容:
class Solution(object):def __init__(self):self.count = 0def totalNQueens(self, n):self.dfs(0, n, 0, 0, 0)return self.countdef dfs(self, row, n, column, diag, antiDiag):if row == n:self.count += 1returnfor index in range(n):isColSafe = (1 << index) & column == 0isDigSafe = (1 << (n - 1 + row - index)) & diag == 0isAntiDiagSafe = (1 << (row + index)) & antiDiag == 0if isAntiDiagSafe and isColSafe and isDigSafe:_________________________;
if __name__ == '__main__':s = Solution()print (s.totalNQueens(4))
解题思路
- 初始化一个计数器 count,用于记录解决方案的数量。
- 定义一个深度优先搜索函数 dfs,用于寻找 n 皇后问题的解决方案。
- 在 dfs 函数中,使用递归的方式进行深度优先搜索。
- 对于每一行,遍历每一列,检查当前位置是否安全(即没有其他皇后在同一行、同一列或同一对角线上)。
- 如果当前位置安全,继续搜索下一行,并更新 column、diag 和 antiDiag 的值。
- 如果已经放置了 n 个皇后,找到一个解决方案,增加计数器 count 的值。
- 返回计数器 count 的值作为解决方案数量。
代码思路
-
定义一个名为Solution的类,包含一个初始化方法__init__和一个计算解决方案数量的方法totalNQueens。
-
在初始化方法中,将计数器count初始化为0。
class Solution(object):def __init__(self):self.count = 0 # 初始化计数器为0 -
在totalNQueens方法中,调用深度优先搜索函数dfs,传入初始参数row=0, n=棋盘大小, column=0, diag=0, antiDiag=0。
def totalNQueens(self, n):"""计算n皇后问题的解决方案数量:param n: 棋盘大小:return: 解决方案数量"""self.dfs(0, n, 0, 0, 0) # 从第0行开始深度优先搜索return self.count # 返回解决方案数量 -
在dfs函数中,使用递归的方式进行深度优先搜索。
def dfs(self, row, n, column, diag, antiDiag):"""深度优先搜索函数,用于寻找n皇后问题的解决方案:param row: 当前行数:param n: 棋盘大小:param column: 列掩码,表示已经放置的皇后所在的列:param diag: 主对角线掩码,表示已经放置的皇后所在的主对角线:param antiDiag: 副对角线掩码,表示已经放置的皇后所在的副对角线""" -
如果已经放置了n个皇后,找到一个解决方案,增加计数器self.count的值。
if row == n: # 如果已经放置了n个皇后,找到一个解决方案self.count += 1 # 增加解决方案计数器return -
遍历每一列,检查当前位置是否安全(即没有其他皇后在同一行、同一列或同一对角线上)。
for index in range(n): # 遍历每一列 -
如果当前位置安全,继续搜索下一行,更新column、diag和antiDiag的值。
-
最后,返回计数器self.count的值作为解决方案的数量。
isColSafe = (1 << index) & column == 0 # 检查当前列是否安全isDigSafe = (1 << (n - 1 + row - index)) & diag == 0 # 检查主对角线是否安全isAntiDiagSafe = (1 << (row + index)) & antiDiag == 0 # 检查副对角线是否安全if isAntiDiagSafe and isColSafe and isDigSafe: # 如果当前位置安全,继续搜索下一行self.dfs(row + 1, n, (1 << index) | column, (1 << (n - 1 + row - index)) | diag, (1 << (row + index)) | antiDiag) -
在主程序中,创建一个Solution对象s,并调用totalNQueens方法,传入棋盘大小n=4,输出4皇后问题的解决方案数量。
if __name__ == '__main__':s = Solution() # 创建Solution对象print(s.totalNQueens(4)) # 输出4皇后问题的解决方案数量
参考代码
这段代码是使用深度优先搜索算法来寻找所有可能的解决方案,并返回解决方案的数量。
self.dfs(row + 1, n, (1 << index) | column,(1 << (n - 1 + row - index)) | diag,(1 << (row + index)) | antiDiag)
买卖股票的最佳时机 II
题目
给定一个数组 prices ,其中 prices[i] 是一支给定股票第 i 天的价格。
设计一个算法来计算你所能获取的最大利润。你可以尽可能地完成更多的交易(多次买卖一支股票)。
注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票)。
示例 1:
输入: prices = [7,1,5,3,6,4]
输出: 7
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 3 天(股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
随后,在第 4 天(股票价格 = 3)的时候买入,在第 5 天(股票价格 = 6)的时候卖出, 这笔交易所能获得利润 = 6-3 = 3 。
示例 2:
输入: prices = [1,2,3,4,5]
输出: 4
解释: 在第 1 天(股票价格 = 1)的时候买入,在第 5 天 (股票价格 = 5)的时候卖出, 这笔交易所能获得利润 = 5-1 = 4 。
注意你不能在第 1 天和第 2 天接连购买股票,之后再将它们卖出。因为这样属于同时参与了多笔交易,你必须在再次购买前出售掉之前的股票。
示例 3:
输入: prices = [7,6,4,3,1]
输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。
提示:
1 <= prices.length <= 3 * 104
0 <= prices[i] <= 104
解题思路
- 初始化两个变量,hold表示持有股票的标志,0表示不持有,1表示持有;pric用于记录买入和卖出的价格;temp用于记录每次交易的利润;flag表示买入价格的索引;msum表示最大利润。
- 如果价格列表长度小于等于2,直接计算最大利润。如果价格列表为空,返回0;如果只有一个价格,返回0;如果第一个价格大于第二个价格,返回0;如果第一个价格小于第二个价格,返回第二个价格减去第一个价格。
- 遍历价格列表,找到买入和卖出的价格。如果下一个价格大于当前价格且不持有股票,将持有标志设为1,记录买入价格的索引,继续遍历;如果下一个价格小于当前价格且持有股票,将买入和卖出的价格分别添加到pric列表中,将持有标志设为0,继续遍历;否则,继续遍历。
- 计算每次交易的利润,并更新最大利润。遍历pric列表,每次取相邻的两个元素作为买入和卖出价格,计算利润,并将利润添加到temp列表中。然后更新最大利润msum为temp列表中所有元素的和。
- 如果最后还持有股票,将最后一天的价格加入最大利润。计算最后一天与买入价格之间的差值,加到最大利润msum上。
- 返回最大利润msum。
代码思路
-
定义一个类
Solution,包含一个方法maxProfit,接收一个参数prices,表示股票价格的列表。 -
初始化变量
hold为0,表示持有股票的标志;pric为空列表,用于记录买入和卖出的价格;temp为空列表,用于记录每次交易的利润;flag为0,表示买入价格的索引;msum为0,表示最大利润。hold = 0 # 持有股票的标志,0表示不持有,1表示持有pric = [] # 记录买入和卖出的价格temp = [] # 记录每次交易的利润flag = 0 # 记录买入价格的索引msum = 0 # 记录最大利润 -
如果价格列表长度小于等于2,直接计算最大利润。如果价格列表为空,返回0;如果只有一个价格,返回0;如果第一个价格大于第二个价格,返回0;如果第一个价格小于第二个价格,返回第二个价格减去第一个价格。
# 如果价格列表长度小于等于2,直接计算最大利润if len(prices) <= 2:if not prices:return 0if len(prices) == 1:return 0if prices[0] > prices[1]:return 0if prices[0] < prices[1]:return prices[1] - prices[0] -
遍历价格列表,找到买入和卖出的价格。如果下一个价格大于当前价格且不持有股票,将持有标志设为1,记录买入价格的索引;如果下一个价格小于当前价格且持有股票,将买入和卖出的价格分别添加到
pric列表中,并将持有标志设为0。# 遍历价格列表,找到买入和卖出的价格for i in range(len(prices) - 1):if prices[i + 1] > prices[i] and hold != 1:hold = 1flag = icontinueif prices[i + 1] < prices[i] and hold == 1:pric.append(prices[flag])pric.append(prices[i])hold = 0else:continue -
计算每次交易的利润,将每次交易的利润添加到
temp列表中,并更新最大利润。# 计算每次交易的利润,并更新最大利润for i in range(0, len(pric), 2):temp.append(pric[i + 1] - pric[i])msum = sum(temp) -
如果最后还持有股票,将最后一天的价格加入最大利润。
# 如果最后还持有股票,将最后一天的价格加入最大利润if hold == 1:msum = msum + prices[-1] - prices[flag] -
返回最大利润。
参考代码
这段代码是一个股票交易问题的解法,通过遍历价格列表来找到买入和卖出的价格,并计算每次交易的利润。
class Solution(object):def maxProfit(self, prices):""":type prices: List[int]:rtype: int"""hold = 0pric = []temp = []flag = 0msum = 0if len(prices) <= 2:if not prices:return 0if len(prices) == 1:return 0if prices[0] > prices[1]:return 0if prices[0] < prices[1]:return prices[1] - prices[0]for i in range(len(prices) - 1):if prices[i + 1] > prices[i] and hold != 1:hold = 1flag = icontinueif prices[i + 1] < prices[i] and hold == 1:pric.append(prices[flag])pric.append(prices[i])hold = 0else:continuefor i in range(0, len(pric), 2):temp.append(pric[i + 1] - pric[i])msum = sum(temp)if hold == 1:msum = msum + prices[-1] - prices[flag]return msum
编程通过键盘输入每一位运动员
题目
体操比赛成绩统计。多名运动员,多个评委打分,去掉一个最高分和去掉一个最低分,对其余分数求平均分作为一个运动员成绩。 编程通过键盘输入每位运动员编号和每个评委的成绩,求出运动员的最终成绩,并将运动员编号和最终成绩保存在一个字典中,形如{编号1:最终成绩1,学号2:最终成绩2…,并将结果输出。
解题思路
- 首先,我们需要获取评委人数和学生人数,确保评委人数不少于3人,学生人数不少于1人。
- 然后,我们需要初始化一个空的学生列表,用于存储每个学生的相关信息。
- 接下来,我们需要遍历学生人数,对于每个学生,我们需要初始化一个包含评分列表、学号、最低分、最高分和平均分的字典。
- 在每个学生字典中,我们需要输入学生的学号,并遍历评委人数,获取每个评委的评分,并将其添加到评分列表中。
- 对评分列表进行排序,然后去掉最低分和最高分,计算剩余分数的平均分,并将结果更新到学生字典中。
- 将学生字典添加到学生列表中。
- 使用字典推导式生成学生学号和最终成绩的字典。
- 最后,输出结果。
代码思路
-
首先,通过输入获取评委人数和学生人数。
-
然后,初始化一个空的学生列表。
# 输入评委人数,不得少于3人 t = int(input('请输入评委人数(不得少于3人):'))# 输入学生人数,不得少于1人 s = int(input('请输入学生人数(不得少于1人):'))# 初始化学生列表 stus = [] -
接着,遍历学生人数,对于每个学生,初始化一个包含评分列表、学号、最低分、最高分和平均分的字典。
# 遍历学生人数 for i in range(s):# 初始化学生字典,包含评分列表、学号、最低分、最高分和平均分stu = {'score':[]} -
在每个学生字典中,通过输入获取学生的学号,并遍历评委人数,获取每个评委的评分,并将其添加到评分列表中。
# 输入学生学号stu.update({'sn':str(input('----\n请输入学生学号:'))})# 遍历评委人数for j in range(t):# 输入评委的评分stu['score'].append(input('请输入评委'+str(j+1)+'的评分:')) -
对评分列表进行排序,然后获取最低分和最高分,并计算平均分。
# 对评分列表进行排序stu['score'].sort()# 获取最低分stu.update({'min':stu['score'].pop(0)})# 获取最高分stu.update({'max':stu['score'].pop()})# 计算平均分并更新字典stu.update({'avg':sum(stu['score'])/len(stu['score'])}) -
将学生字典添加到学生列表中。
# 将学生字典添加到学生列表中stus.append(stu) -
最后,使用字典推导式生成学生学号和平均分的字典,并输出结果。
# 使用字典推导式生成学生学号和平均分的字典
r = {n['sn']:n['avg'] for n in stus}
参考代码
t = int(input('请输入评委人数(不得少于3人):'))
s = int(input('请输入学生人数(不得少于1人):'))
stus = []
for i in range(s):stu = {'score':[]}stu.update({'sn':str(input('----\n请输入学生学号:'))})for j in range(t):stu['score'].append(input('请输入评委'+str(j+1)+'的评分:'))stu['score'].sort()stu.update({'min':stu['score'].pop(0)})stu.update({'max':stu['score'].pop()})stu.update({'avg':eval('+'.join(stu['score']))/len(stu['score'])})stus.append(stu)
r = {n['sn']:n['avg'] for n in stus}
print(r)
相关文章:
CSDN每日一题学习训练——Python版(N皇后 II、买卖股票的最佳时机 II、编程通过键盘输入每一位运动员)
版本说明 当前版本号[20231120]。 版本修改说明20231120初版 目录 文章目录 版本说明目录N皇后 II题目解题思路代码思路参考代码 买卖股票的最佳时机 II题目解题思路代码思路参考代码 编程通过键盘输入每一位运动员题目解题思路代码思路参考代码 N皇后 II 题目 n 皇后问题…...
semodule工具详解(1)
本文内容参考: semodule(8) - Linux manual page https://linux.die.net/man/8/semodule 1. 介绍 名称 semoudule —— 管理SELinux策略模块。 简介 semodule [options]... MODE [MODES]... 描述 semodule是用于管理SELinux策略模块的工具,包括安装…...
用百度AI大模型给头像换风格
心血来潮想尝试尝试AI小应用,给图片加个风格(例如微信头像),于是有了这篇简短的教程 目录 1. 领取免费资源2. 在应用列表创建应用3. 在线API调试4. 效果对比 1. 领取免费资源 网站:百度智能云 百度给提供了很多AIGC的…...
从入门到精通,mac电脑录屏软件使用教程!
“mac电脑怎么录屏呀,刚买了一台mac电脑,用了几个月感觉挺流畅的,最近因为工作原因,需要用到录屏功能,但是我不会操作,想问问大家有没有简单易懂的录屏教程,谢谢啦。” 在日常生活中࿰…...
Nginx(反向代理,负载均衡,动静分离)
反向代理 Nginx反向代理是一种将客户端请求转发给后端服务器的技术,即反向代理服务器。在这种架构中,客户端请求首先到达Nginx服务器,然后由Nginx服务器将请求转发给后端服务器,后端服务器响应请求,并将响应传递回Ngi…...
【Spring】SpringBoot的扩展点之ApplicationContextInitializer
简介 其实spring启动步骤中最早可以进行扩展的是实现ApplicationContextInitializer接口。来看看这个接口的注释。 package org.springframework.context;/*** Callback interface for initializing a Spring {link ConfigurableApplicationContext}* prior to being {linkpl…...
哈希表HashTable
散列表(Hash table,也叫哈希表),是根据键(Key)而直接访问在内存存储位置的数据结构。 哈希表中关键码就是数组的索引下标,然后通过下标直接访问数组中的元素,复杂度O(1) 哈希表本质…...
【软件测试】一位优秀测试工程师具备哪些知识和经验?
目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 根据观察…...
MongoDB相关基础操作(库、集合、文档)
文章目录 一、库的相关操作1、查看数据库2、查看当前库3、创建数据库4、删除数据库 二、集合的相关操作1、查看库中所有集合2、创建集合2.1、显示创建2.2、隐式创建 3、删除集合 三、文档的相关操作1、插入文档1.1、插入单条文档1.2、插入多条文档1.3、脚本方式 2、查询文档3、…...
进程和线程( Process and Thread)
目录 一、操作系统(Operating System) 操作系统的定位 二、 什么是进程/任务(Process/Task) 1.进程控制块抽象(PCB Process Control Block) 2.PCB中重要的属性 3.并发编程 三、线程(Thread) 1. 线程是…...
linux apache安装及虚拟主机配置
centos 安装apache, yum install httpd 将httpd.conf中的ServerName 前面的 # 去掉。 apache 2.2 的虚拟机的配置放置在conf/extra/httpd-vhosts.conf 中 apache 虚拟主机设置 a2enmod rewrite sudo vim 000-default 修改 ServerName *:80 <VirtualHost *…...
基于Spring Boot 框架的试卷自动生成系统的设计与实现
项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。你想解决的问题,今天给大家介绍…...
开发《猫咪攻略》小游戏的意义
开发《猫咪攻略》小游戏的意义有以下几点: 学习和掌握游戏开发的基本技能:通过开发《猫咪攻略》小游戏,可以学习和掌握游戏开发的基本技能,包括游戏策划、游戏设计、游戏编程和游戏测试等方面的技能。增强对猫咪的了解和认识&…...
hadoop、hive、DBeaver的环境搭建及使用
本文主要介绍hadoop、hive的结构及使用,具体的操作步骤见最后的附件; hadoop提供大数据的存储、资源调度、计算,分为三个模块:HDFS、YRAN、MapReduce HDFS提供数据的分布式存储,分为三个节点NameNode,DataNode,Second…...
Linux上通过SSL/TLS和start tls连接到LDAP服务器(附C++代码实现认证流程)
一,大致流程。 1.首先在Linux上搭建一个LDAP服务器 2.在LDAP服务器上安装CA证书,服务器证书,因为SSL/TLS,start tls都属于机密通信,需要客户端和服务器都存在一个相同的证书认证双方的身份。3.安装phpldapadmin工具&am…...
HarmonyOS ArkTS List组件和Grid组件的使用(五)
简介 ArkUI提供了List组件和Grid组件,开发者使用List和Grid组件能够很轻松的完成一些列表页面。常见的列表有线性列表(List列表)和网格布局(Grid列表): List组件的使用 List是很常用的滚动类容器组件&…...
考研思想政治理论大纲
一:马克思主义基本原理概论 (一)马克思主义是关于无产阶级和人类解放的科学 1、马克思主义的创立和发展 马克思主义的含义。马克思主义产生的经济社会根源、实践基础和思想渊源、马克思主义的创立、马克思主义在实践中的发展 2、马克思主义的鲜明特征 马克思主义科学性和革命…...
日期格式转化成星期几部署到linux显示英文
异常收集 原因:解决办法仰天大笑出门去,我辈岂是蓬蒿人 传入一个时间获取这个时间对应的是星期几,在开发环境(window系统)中显示为星期几,部署到服务器(linux系统)中会显示英文的时间…...
一个关于proto 文件的经验分享 :gRPC 跨语言双端通信显示错误码:12 UNIMPLEMENTED (附赠gRPC错误码表)
错误现象描述: 在使用c的客户端向golang的服务端发送远程调用时,显示: /home/zry/gRPC/grpc-v1.45.2/examples/cpp/DeviceData/greeter_client.cc83 12: unknown service DeviceData.DeviceDataService Greeter 接收到: RPC 失败这里的unkn…...
腾讯极光盒子A4021增强版_线刷官方
1、用USB_Burning_Tool线刷提供的线刷包,所需资料地址在最后 1)打开USB_Burning_Tool,选择资料里的A4021_line_flash_root.img(文件夹最好没有中文字符和空格),然后点击【开始】。 2)盒子准备好双USB线和电源。在1秒内先插入电源,再插入usb口。等这个软件识别到盒子,…...
KnowLM开源框架:知识增强大模型在信息抽取与对话中的实践指南
1. 项目概述:一个为知识而生的开源大语言模型框架 如果你正在寻找一个能够处理中文和英文、专注于知识增强与信息抽取、并且提供从数据处理到模型部署完整流程的开源大语言模型框架,那么 zjunlp/KnowLM 绝对值得你花时间深入了解。这不是一个简单的模…...
AI命令行工具实战:基于Gemini CLI的完整项目开发与自动化工作流指南
1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的仓库,是DeepLearning.AI一个关于Gemini CLI的短期课程配套资源。这个项目本身叫“sc-gemini-cli-files”,说白了就是一个代码库,里面打包了课程里用到的所有文件:从最开始的…...
深入理解 C++ 标准中的右值引用
C 是一门极为复杂且灵活的编程语言,而右值引用(rvalue reference)是 C11 标准中引入的一项重要特性。它不仅扩展了语言的语法,还提供了全新的编程思路,对资源管理和性能优化起到了巨大的推动作用。 什么是右值引用 在…...
Genkit AI应用框架:统一接口、类型安全与RAG实战指南
1. 从零到一:为什么我们需要 Genkit 这样的 AI 应用框架? 如果你最近在尝试把大语言模型(LLM)集成到自己的应用里,不管是做个智能客服、内容摘要工具,还是更复杂的多步骤工作流,大概率已经踩过…...
CANN/ops-transformer FlashAttention可变长评分
aclnnFlashAttentionVarLenScore 【免费下载链接】ops-transformer 本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。 项目地址: https://gitcode.com/cann/ops-transformer 产品支持情况 产品是否支持Ascend 950PR/Ascend 950DT√A…...
SpaceMolt:AI驱动的实时太空MMO沙盒,探索多智能体社会涌现行为
1. 项目概述:一个由AI驱动的实时太空MMO世界 最近在捣鼓AI Agent应用的时候,发现了一个特别有意思的开源项目,叫 SpaceMolt 。简单来说,它是一个“完全由AI玩家驱动的、大规模的、实时的太空多人在线游戏”。这听起来有点绕&am…...
多模态大模型Awesome列表:从资源导航到高效学习与开发实践
1. 项目概述:一个多模态大模型的“藏宝图” 如果你最近在折腾大语言模型,尤其是对能“看懂”图片、“听懂”声音的多模态模型感兴趣,那你大概率已经听过或搜过“Awesome”系列的开源项目。这类项目通常是一个精心整理的列表,像一张…...
数据驱动的可解释AI:从特征归因到样本影响分析的实践指南
1. 项目概述:当数据挖掘遇见可解释AI在深度学习的浪潮席卷了几乎所有领域之后,我们获得了一个又一个性能惊人的“黑箱”模型。作为一名长期在数据科学一线工作的从业者,我见证了模型精度从90%提升到99.9%的激动,也亲历了当业务方或…...
基于C#winform实现yolo26-plate中文车牌检测识别支持12种中文双层颜色车牌文字识别
效果展示项目简介 这是一个基于深度学习的车牌检测与识别系统,采用 ONNX 模型格式实现,支持 CPU 和 CUDA 加速推理。本项目将 Python 实现的车牌检测识别功能完整移植到 C# 环境,实现了高性能、模块化的车牌识别解决方案。 算法原理 本系统采…...
mac 安装指定node版本
我这里使用的是nvm(Node Version Manager)nvm(Node Version Manager)是一个允许你在同一台机器上安装和管理多个Node.js版本的工具。1.安装nvm打开终端,然后运行以下命令来安装nvm:bash:curl -o- https://r…...
