早就听说Python是一门很强大的语言,不过一直没有什么机会去学。直到前一段时间我的技术群里有人问我了一道Python的题目,本着帮助他人、充实自己的想法,我二话不说就去查找资料,做出了这道题。也算是入坑py了吧_(:з」∠)_
原题如下:
描述
找出矩阵中的最大值,输出最大值及其所在行和列。考虑同时存在多个最大值得情况。
输入格式
使用input()函数输入,不需要任何提示信息。
输出格式
输出时使用'{}’.format()格式,提示信息为“最大值:,所在行:,所在列:”
输入输出示例
输入:[[3,4,1],[6,7,8],[9,6,9]]
输出:最大值:9,所在行:2,所在列:0
最大值:9,所在行:2,所在列:2
实现代码:
import re
zkh=0 #左括号数量
i=int(0) #计数变量
arr_in=input() #源输入
alist = re.findall(r"\d+",arr_in) #分离出整数
alist_int = list(map(int,alist)) #对分离出的整数整型化
length=len(alist_int) #获得数组长度
for x in arr_in:
if x == '[': #获得源输入中左括号的数量,由此判断行数
zkh=zkh+1
fr=zkh-2 #最终行数
fc=int((length/(fr+1))-1) #最终列数
max=alist_int[0] #开始遍历找最大值
while imax:
max=alist_int[i] i=i+1
for row in range(0,fr+1): #开始遍历输出最大值
for col in range(0,fc+1):
sx=row*(fc+1)+col
if(alist_int[sx]==max):
print('最大值:{},所在行:{},所在列:{}'.format(max,row,col))
心得:
1.其实入门py一点也不难。我从一点基础都没有到帮群友做出这道题,前后也只花了半天的时间而已。多试试就可以试出来,用print输出,用input()输入,用'{}'.format()对应格式,用for…in…遍历,用缩进表示代码层次,用#表示注释,等等。世上无难事,只怕有心人。试试也许不会成功,但不试就一定不能成功。后面的爬虫以及游戏应用还很深,慢慢去学习吧。
2.在写这道题的程序时,刚开始有人告诉我可以用numpy库,因为输入中含有嵌套的中括号。但是这个库并不是所有IDE都自带,就不方便。所以查阅资料后我决定使用re库提取其中的数字。那这样的话怎么确定行数和列数呢?在朋友的启发下我发现括号数刚好等于行数+1,通过数出源输入中左括号的个数即可算出行数,再用总数字数除以行数即得矩阵的列数。后面就可以很轻松地遍历了。
感谢你的阅读!第一次写博客,还请多多支持喵!我会加油的~
作者:迷茫的嘉鸿