【python】屈小原求三峡大学面积(CTGU百年校庆)

2023-10-24 14:04

本文主要是介绍【python】屈小原求三峡大学面积(CTGU百年校庆),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目:

"""

题目描述:

屈小原希望你能帮他求出一块地图中学校的面积。地图由nxm个方格组成,每个方格中都有一个小写的英文字母,如果该方格为学校所属,那么该方格必定是一段连续的ctgu的组成部分。从一个特定的字符开始,可以向上、下、左、右四个方向移动到相邻的方格。如果按照这种方式,能够从一个字符按顺序走到另一个字符,形成指定的字符串序列(在这个情况下是“ctgu”),那么这些方格被认为是连续的,即它们是学校的一部分。

输入:

第一行包含两个整数n,m(1<n,m<1000)-地图的大小。接下来的n行包含m个小写字母,描述指定的地图

输出:

对于每组测试数据,输出学校所占的方格数目。

样例1:

4 4

cbug

tgtc

gutc

cgtu

样例输出:

7

"""

代码:

"""
思路:深度优先搜索(DFS)
"""
N = 1000  # 设置二维数组的最大维度。预分配空间
# 在绝大多数情况下,上下左右移动的坐标变化确实应该是 (0, 1)、(0, -1)、(1, 0) 和 (-1, 0)。
dx = [0, 0, 1, -1]  # 定义了在x方向上的四个可能的移动(上下左右)
dy = [1, -1, 0, 0]  # 定义了在y方向上的四个可能的移动
ctgu = "ctgu"  # 目标字符串
# 初始化一个二维字符数组s,用于存储输入的字符数据
s = [['' for _ in range(N)] for _ in range(N)]  
# 初始化一个二维访问数组vis,用于标记某个位置是否被访问过
vis = [[0 for _ in range(N)] for _ in range(N)]def dfs(x, y, stk):u = len(stk)  # 获取当前堆栈的大小if u == 4:  # 如果堆栈大小为4,标记堆栈中所有位置为已访问,并终止搜索for i in range(4):# 元组,stk[i][0]表示第i个位置的x坐标,stk[i][1]表示第i个位置的y坐标vis[stk[i][0]][stk[i][1]] = 1returnfor i in range(4):  # 循环遍历四个可能的方向tx = x + dx[i]  # 计算新的x位置ty = y + dy[i]  # 计算新的y位置# 检查新位置是否在边界内,堆栈大小是否小于目标字符串的长度,和新位置的字符是否匹配目标字符串的当前字符if 0 <= tx < n and 0 <= ty < m and u < len(ctgu) and s[tx][ty] == ctgu[u]:# 如果满足条件,将新位置元组(tx, ty)添加到堆栈中stk.append((tx, ty))dfs(tx, ty, stk)  # 递归调用DFS函数stk.pop()  # 回溯:从堆栈中弹出最后一个位置  返回的是地图坐标n, m = map(int, input().split())  # 输入n和m的值
for i in range(n):s[i] = list(input())  # 将输入的字符串转换为字符列表,并赋值给s数组的对应行
for i in range(n):for j in range(m):stk = []  # 初始化一个空堆栈dfs(i, j, stk)  # 从位置(i, j)开始执行DFSans = 0  # 初始化答案变量为0
for i in range(n):for j in range(m):if vis[i][j]:  # 如果位置(i, j)被访问过,增加答案变量ans += 1
print(ans)  # 输出最终答案

 

这篇关于【python】屈小原求三峡大学面积(CTGU百年校庆)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/275682

相关文章

Python中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2

Python虚拟环境终极(含PyCharm的使用教程)

《Python虚拟环境终极(含PyCharm的使用教程)》:本文主要介绍Python虚拟环境终极(含PyCharm的使用教程),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录一、为什么需要虚拟环境?二、虚拟环境创建方式对比三、命令行创建虚拟环境(venv)3.1 基础命令3

Python Transformer 库安装配置及使用方法

《PythonTransformer库安装配置及使用方法》HuggingFaceTransformers是自然语言处理(NLP)领域最流行的开源库之一,支持基于Transformer架构的预训练模... 目录python 中的 Transformer 库及使用方法一、库的概述二、安装与配置三、基础使用:Pi

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Python基础语法中defaultdict的使用小结

《Python基础语法中defaultdict的使用小结》Python的defaultdict是collections模块中提供的一种特殊的字典类型,它与普通的字典(dict)有着相似的功能,本文主要... 目录示例1示例2python的defaultdict是collections模块中提供的一种特殊的字

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析