CSDN每日一题学习训练——Python版(N皇后 II、买卖股票的最佳时机 II、编程通过键盘输入每一位运动员)

news2025/1/6 17:33:30

版本说明

当前版本号[20231120]。

版本修改说明
20231120初版

目录

文章目录

  • 版本说明
  • 目录
  • N皇后 II
    • 题目
    • 解题思路
    • 代码思路
    • 参考代码
  • 买卖股票的最佳时机 II
    • 题目
    • 解题思路
    • 代码思路
    • 参考代码
  • 编程通过键盘输入每一位运动员
    • 题目
    • 解题思路
    • 代码思路
    • 参考代码

N皇后 II

题目

n 皇后问题 研究的是如何将 n 个皇后放置在 n×n 的棋盘上,并且使皇后彼此之间不能相互攻击。

给你一个整数 n ,返回 n 皇后问题 不同的解决方案的数量。

示例 1:

image-20231120205216429

输入:n = 4
输出:2
解释:如上图所示,4 皇后问题存在两个不同的解法。

示例 2:

输入:n = 1
输出:1

提示:

1 <= n <= 9
皇后彼此不能相互攻击,也就是说:任何两个皇后都不能处于同一条横行、纵行或斜线上。

以下程序实现了这一功能,请你填补空白处内容:

class Solution(object):
	def __init__(self):
		self.count = 0
	def totalNQueens(self, n):
		self.dfs(0, n, 0, 0, 0)
		return self.count
	def dfs(self, row, n, column, diag, antiDiag):
		if row == n:
			self.count += 1
			return
		for index in range(n):
			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:
				_________________________;
if __name__ == '__main__':
	s = Solution()
	print (s.totalNQueens(4))

解题思路

  1. 初始化一个计数器 count,用于记录解决方案的数量。
  2. 定义一个深度优先搜索函数 dfs,用于寻找 n 皇后问题的解决方案。
  3. 在 dfs 函数中,使用递归的方式进行深度优先搜索。
  4. 对于每一行,遍历每一列,检查当前位置是否安全(即没有其他皇后在同一行、同一列或同一对角线上)。
  5. 如果当前位置安全,继续搜索下一行,并更新 column、diag 和 antiDiag 的值。
  6. 如果已经放置了 n 个皇后,找到一个解决方案,增加计数器 count 的值。
  7. 返回计数器 count 的值作为解决方案数量。

代码思路

  1. 定义一个名为Solution的类,包含一个初始化方法__init__和一个计算解决方案数量的方法totalNQueens。

  2. 在初始化方法中,将计数器count初始化为0。

    class Solution(object):
        def __init__(self):
            self.count = 0  # 初始化计数器为0
    
  3. 在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  # 返回解决方案数量
    
  4. 在dfs函数中,使用递归的方式进行深度优先搜索。

     def dfs(self, row, n, column, diag, antiDiag):
            """
            深度优先搜索函数,用于寻找n皇后问题的解决方案
            :param row: 当前行数
            :param n: 棋盘大小
            :param column: 列掩码,表示已经放置的皇后所在的列
            :param diag: 主对角线掩码,表示已经放置的皇后所在的主对角线
            :param antiDiag: 副对角线掩码,表示已经放置的皇后所在的副对角线
            """
    
  5. 如果已经放置了n个皇后,找到一个解决方案,增加计数器self.count的值。

       if row == n:  # 如果已经放置了n个皇后,找到一个解决方案
                self.count += 1  # 增加解决方案计数器
                return
    
  6. 遍历每一列,检查当前位置是否安全(即没有其他皇后在同一行、同一列或同一对角线上)。

       for index in range(n):  # 遍历每一列
    
  7. 如果当前位置安全,继续搜索下一行,更新column、diag和antiDiag的值。

  8. 最后,返回计数器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)
    
  9. 在主程序中,创建一个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

解题思路

  1. 初始化两个变量,hold表示持有股票的标志,0表示不持有,1表示持有;pric用于记录买入和卖出的价格;temp用于记录每次交易的利润;flag表示买入价格的索引;msum表示最大利润。
  2. 如果价格列表长度小于等于2,直接计算最大利润。如果价格列表为空,返回0;如果只有一个价格,返回0;如果第一个价格大于第二个价格,返回0;如果第一个价格小于第二个价格,返回第二个价格减去第一个价格。
  3. 遍历价格列表,找到买入和卖出的价格。如果下一个价格大于当前价格且不持有股票,将持有标志设为1,记录买入价格的索引,继续遍历;如果下一个价格小于当前价格且持有股票,将买入和卖出的价格分别添加到pric列表中,将持有标志设为0,继续遍历;否则,继续遍历。
  4. 计算每次交易的利润,并更新最大利润。遍历pric列表,每次取相邻的两个元素作为买入和卖出价格,计算利润,并将利润添加到temp列表中。然后更新最大利润msum为temp列表中所有元素的和。
  5. 如果最后还持有股票,将最后一天的价格加入最大利润。计算最后一天与买入价格之间的差值,加到最大利润msum上。
  6. 返回最大利润msum。

代码思路

  1. 定义一个类Solution,包含一个方法maxProfit,接收一个参数prices,表示股票价格的列表。

  2. 初始化变量hold为0,表示持有股票的标志;pric为空列表,用于记录买入和卖出的价格;temp为空列表,用于记录每次交易的利润;flag为0,表示买入价格的索引;msum为0,表示最大利润。

    	hold = 0  # 持有股票的标志,0表示不持有,1表示持有
            pric = []  # 记录买入和卖出的价格
            temp = []  # 记录每次交易的利润
            flag = 0  # 记录买入价格的索引
            msum = 0  # 记录最大利润
    
  3. 如果价格列表长度小于等于2,直接计算最大利润。如果价格列表为空,返回0;如果只有一个价格,返回0;如果第一个价格大于第二个价格,返回0;如果第一个价格小于第二个价格,返回第二个价格减去第一个价格。

      # 如果价格列表长度小于等于2,直接计算最大利润
            if len(prices) <= 2:
                if not prices:
                    return 0
                if len(prices) == 1:
                    return 0
                if prices[0] > prices[1]:
                    return 0
                if prices[0] < prices[1]:
                    return prices[1] - prices[0]
    
  4. 遍历价格列表,找到买入和卖出的价格。如果下一个价格大于当前价格且不持有股票,将持有标志设为1,记录买入价格的索引;如果下一个价格小于当前价格且持有股票,将买入和卖出的价格分别添加到pric列表中,并将持有标志设为0。

      # 遍历价格列表,找到买入和卖出的价格
            for i in range(len(prices) - 1):
                if prices[i + 1] > prices[i] and hold != 1:
                    hold = 1
                    flag = i
                    continue
                if prices[i + 1] < prices[i] and hold == 1:
                    pric.append(prices[flag])
                    pric.append(prices[i])
                    hold = 0
                else:
                    continue
    
  5. 计算每次交易的利润,将每次交易的利润添加到temp列表中,并更新最大利润。

    # 计算每次交易的利润,并更新最大利润
            for i in range(0, len(pric), 2):
                temp.append(pric[i + 1] - pric[i])
                msum = sum(temp)
    
  6. 如果最后还持有股票,将最后一天的价格加入最大利润。

      # 如果最后还持有股票,将最后一天的价格加入最大利润
            if hold == 1:
                msum = msum + prices[-1] - prices[flag]
    
  7. 返回最大利润。

参考代码

这段代码是一个股票交易问题的解法,通过遍历价格列表来找到买入和卖出的价格,并计算每次交易的利润。

class Solution(object):
    def maxProfit(self, prices):
        """
        :type prices: List[int]
        :rtype: int
        """
        hold = 0
        pric = []
        temp = []
        flag = 0
        msum = 0
        if len(prices) <= 2:
            if not prices:
                return 0
            if len(prices) == 1:
                return 0
            if prices[0] > prices[1]:
                return 0
            if 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 = 1
                flag = i
                continue
            if prices[i + 1] < prices[i] and hold == 1:
                pric.append(prices[flag])
                pric.append(prices[i])
                hold = 0
            else:
                continue
        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]
        return msum

编程通过键盘输入每一位运动员

题目

体操比赛成绩统计。多名运动员,多个评委打分,去掉一个最高分和去掉一个最低分,对其余分数求平均分作为一个运动员成绩。 编程通过键盘输入每位运动员编号和每个评委的成绩,求出运动员的最终成绩,并将运动员编号和最终成绩保存在一个字典中,形如{编号1:最终成绩1,学号2:最终成绩2…,并将结果输出。

解题思路

  1. 首先,我们需要获取评委人数和学生人数,确保评委人数不少于3人,学生人数不少于1人。
  2. 然后,我们需要初始化一个空的学生列表,用于存储每个学生的相关信息。
  3. 接下来,我们需要遍历学生人数,对于每个学生,我们需要初始化一个包含评分列表、学号、最低分、最高分和平均分的字典。
  4. 在每个学生字典中,我们需要输入学生的学号,并遍历评委人数,获取每个评委的评分,并将其添加到评分列表中。
  5. 对评分列表进行排序,然后去掉最低分和最高分,计算剩余分数的平均分,并将结果更新到学生字典中。
  6. 将学生字典添加到学生列表中。
  7. 使用字典推导式生成学生学号和最终成绩的字典。
  8. 最后,输出结果。

代码思路

  1. 首先,通过输入获取评委人数和学生人数。

  2. 然后,初始化一个空的学生列表。

    # 输入评委人数,不得少于3人
    t = int(input('请输入评委人数(不得少于3人):'))
    
    # 输入学生人数,不得少于1人
    s = int(input('请输入学生人数(不得少于1人):'))
    
    # 初始化学生列表
    stus = []
    
  3. 接着,遍历学生人数,对于每个学生,初始化一个包含评分列表、学号、最低分、最高分和平均分的字典。

    # 遍历学生人数
    for i in range(s):
        # 初始化学生字典,包含评分列表、学号、最低分、最高分和平均分
        stu = {'score':[]}
    
  4. 在每个学生字典中,通过输入获取学生的学号,并遍历评委人数,获取每个评委的评分,并将其添加到评分列表中。

     # 输入学生学号
        stu.update({'sn':str(input('----\n请输入学生学号:'))})
        
        # 遍历评委人数
        for j in range(t):
            # 输入评委的评分
            stu['score'].append(input('请输入评委'+str(j+1)+'的评分:'))
    
  5. 对评分列表进行排序,然后获取最低分和最高分,并计算平均分。

      # 对评分列表进行排序
        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'])})
    
  6. 将学生字典添加到学生列表中。

    # 将学生字典添加到学生列表中
        stus.append(stu)
    
  7. 最后,使用字典推导式生成学生学号和平均分的字典,并输出结果。

# 使用字典推导式生成学生学号和平均分的字典
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)

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

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

相关文章

Nginx - 本机读取服务器图像、视频

目录 一.引言 二.安装 Nginx 1.安装 By apt 2.安装 By 官网 三.配置 Nginx 1.Linux 机器配置 2.重启 Nginx 服务 3.本机查看机器文件 四.总结 一.引言 前面介绍了 GFP-GAN、PNG2GIF、GIF2PNG 等操作&#xff0c;我们生成的 video、gif、png 等形式的文件都存储在 lin…

【Qt开发流程】之程序主窗口

描述 就目前的应用程序而言&#xff0c;一般包含菜单栏、工具栏、状态栏、中央区域等。 qt窗口部件类图如下&#xff1a; 一个主窗口提供了一个构建应用程序用户界面的框架。 Qt有QMainWindow及其相关类来管理主窗口。 QMainWindow有自己的布局&#xff0c;可以向其中添加QTo…

苹果(Apple)公司的新产品开发流程(一)

目录 简介 ANPP CSDN学院推荐 作者简介 简介 苹果这家企业给人的长期印象就是颠覆和创新。 而流程跟创新似乎是完全不搭边的两个平行线&#xff1a; 流程是一个做事的标准&#xff0c;定义了权力的边界&#xff0c;对应人员按章办事&#xff1b;而创新的主旋律是发散&am…

IDEA前端thymeleaf只显示部分数据库问题

只显示int类型的number&#xff0c;不显示string类型的price和weight 先看一下apple.html <!DOCTYPE html> <html xmlns:th"http://www.thymeleaf.org"> <head><meta charset"UTF-8"><title>User List</title> </…

游戏报错d3dcompiler_47.dll缺失怎么修复,总结多种修复方法

在使用这些软件和游戏的过程中&#xff0c;我们常常会遇到一些问题&#xff0c;其中之一就是d3dcompiler_47.dll丢失的问题。这个问题可能会导致软件或游戏无法正常运行&#xff0c;给用户带来困扰。本文将详细介绍解决软件游戏d3dcompiler_47.dll丢失的方法&#xff0c;帮助您…

C语言——函数的嵌套调用

#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h>void new_line() {printf("Hello\n"); }void three_line() {int i0;for(i0;i<3;i){new_line();} }int main() {three_line();return 0; }

Linux程序设计(上)

系列文章目录 文章目录 系列文章目录前言一、unix, linux, GNU, POSIXLinux程序 二、shellshell语法1.变量2.语句 函数命令命令的执行dialog工具-- 三、文件操作1. Linux 文件结构2. 系统调用和设备驱动程序3. 库函数4. 底层文件访问5. 标准I/O库6.格式化输入输出7. 文件和目录…

视频剪辑方法:一键批量调整色调的高效技巧

在视频剪辑的过程中&#xff0c;色调调整是一项非常重要的工作。它能够改变影片的氛围、情感和视觉效果&#xff0c;更好地沉浸在影片的情境中。然而&#xff0c;对于许多视频剪辑师来说&#xff0c;批量调整色调是一项非常繁琐的任务&#xff0c;需要耗费大量的时间和精力。色…

C++学习笔记——C++ deque和vector的区别

C中的std::deque&#xff08;双端队列&#xff09;和std::vector&#xff08;向量&#xff09;是两种不同的容器类型&#xff0c;它们有以下区别&#xff1a; 内部实现方式不同&#xff1a;std::deque使用了一种双端队列的数据结构&#xff0c;它由多个块&#xff08;chunks&am…

RFID井盖管理系统解决方案

随着我国城市基础设施建设事业的迅速发展&#xff0c;城市中的通讯、燃气、给水、排水、热力、电力等各类市政公用地下管线设施不断增加&#xff0c;相应地&#xff0c;城市路面上的井盖也越来越多。然而&#xff0c;近年来&#xff0c;由于城市井盖管理不善&#xff0c;井盖被…

Codeforces Round 908 (Div. 2)

一个教训&#xff1a;做题的时候一定要自己模拟一遍所有样例&#xff0c;这样思路出来的很快&#xff01;&#xff01;&#xff01; C. Anonymous Informant Example input Copy 6 5 3 4 3 3 2 3 3 100 7 2 1 5 5 6 1 1 1 1 1 1000000000 1 8 48 9 10 11 12 13 14 …

C++设计模式——单例模式

单例设计模式 应用场景特点设计模式分类懒汉设计模式饿汉设计模式使用编写的测试代码运行结果 应用场景 当多个类都需要调用某一个类的一些公共接口&#xff0c;同时不想创建多个该类的对象&#xff0c;可以考虑将该类封装为一个单例模式。 特点 单例模式的特点&#xff1a;…

python -opencv 边缘检测

python -opencv 边缘检测 边缘检测步骤: 第一步&#xff1a;读取图像为灰度图 第二步&#xff1a;进行二值化处理 第三步&#xff1a;使用cv2.findContours对二值化图像提取轮廓 第三步&#xff1a;将轮廓绘制到图中 代码如下&#xff1a; from ctypes.wintypes import SIZ…

基于Vue+SpringBoot的医院门诊预约挂号系统 开源项目

项目编号&#xff1a; S 033 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S033&#xff0c;文末获取源码。} 项目编号&#xff1a;S033&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 功能性需求2.1.1 数据中心模块2.1.2…

使用cli批量下载GitHub仓库中所有的release

文章目录 1\. 引言2\. 工具官网3\. 官方教程4\. 测试用的网址5\. 安装5.1. 使用winget安装5.2. 查看gh是否安装成功了 6\. 使用6.1. 进行GitHub授权6.1.1. 授权6.1.2. 授权成功6.2 查看指定仓库中的所有版本的release6.2.1. 默认的30个版本6.2.2. 自定义的100个版本6.3 下载特定…

华为数通HCIP 821BGP 知识点整理

个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢AI编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;落798. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&#x1f5bc;️…

《数据:挖掘价值,洞察未来

大数据&#xff1a;挖掘价值&#xff0c;洞察未来 我们正身处一个数据驱动的时代&#xff0c;大数据已经成为企业和个人决策的重要依据。本文将深入探讨大数据的魅力&#xff0c;挖掘其价值&#xff0c;并洞察未来发展趋势&#xff0c;让我们一起领略大数据的无穷奥秘。 一、大…

js-WebApi笔记之BOM

目录 window对象 定时器-延迟函数 location对象 navigator对象 histroy对象 本地存储 localStorage sessionStorage localStorage 存储复杂数据类型 window对象 BOM (Browser Object Model ) 是浏览器对象模型 window对象是一个全局对象&#xff0c;也可以说是JavaScr…

Redis字典实现

前言 字典又称符号表&#xff0c;关联数组或者映射(map)。是一种保存键值对的抽象数据结构。在字典中一个键和一个值进行关联。这些关联的值被称为键值对。 字典中每一个键都是独一无二的&#xff0c;没有重复的。我们可以通过键来查找值&#xff0c;更新值或者删除整个键值对等…

svn问题集

被锁定&#xff0c;无法拉取提交 解决方法