导航

一、找到已经最大承重的背包内如何放入最大价值的物品的最优解

二、查找一个字符串中包含另外一个字符串(可打乱顺序)的次数
三、计算正整数数组从头走到最后一个成员所需的最小步骤
四、计算字符串非严格递增连续数字序列的长度
五、输出这个数列的第n项结果,数列中a[n+1]都是a[n]的描述
六、计算多维数组中最大子矩阵内所有数字的和
七、还原一个已经打乱顺序的喊7游戏的数组
八、计算满足GPU算力的一组任务组的最少耗时
九、计算字符串中连续出现次数第k多的字母的次数
十、计算一个整数可以由连续的自然数之和的各种情况
十一、给定一个正整数数组,计算满足 A = B + 2C的数组序列
十二、根据 Tag Length Value格式解码TLV编码

- - - - - 分割线 - - - - -
三、计算正整数数组从头走到最后一个成员所需的最小步骤
描述:给定一个正整数数组,设为nums,最大为100个成员,求从第一个成员开始,正好走到数组最后一个成员,所使用的最少步骤数。
要求:
1、第一步必须从第一元素开始,且1<=第一步的步长<len/2;(len为数组的长度,需要自行解析)。
2、从第二步开始,只能以所在成员的数字走相应的步数,不能多也不能少, 如果目标不可达返回-1,只输出最少的步骤数量。
3、只能向数组的尾部走,不能往回走。
输入描述:
由正整数组成的数组,以空格分隔,数组长度小于100,请自行解析数据数量。
输出描述:
正整数,表示最少的步数,如果不存在输出-1
示例:
输入
5 9 4 2 6 8 3 5 4 3 9
输出
2

解析:遍历数组,分别从第一步出发,将满足条件的数据记录并比较取最小值。

nums = list(map(int, input().split()))
length = len(nums)
min_step,move_step,flag = length,1,False
for first_step in range(1,int(length/2)):
move_step = first_step
step = 1
while move_step < length - 1:
step += 1
move_step += nums[move_step]
if move_step == length - 1:
min_step = min(min_step,step)
flag = True
print(min_step if flag else -1)

四、计算字符串非严格递增连续数字序列的长度

描述:输入一个字符串仅包含大小写字母和数字,求字符串中包含的最长的非严格递增连续数字序列的长度(比如12234属于非严格递增连续数字序列)。
输入描述:
输入一个字符串仅包含大小写字母和数字,输入的字符串最大不超过255个字符。
输出描述:
最长的非严格递增连续数字序列的长度
示例:
输入:
abc2234019A334bc
输出:
4

解析:定义上一个符合条件的数字,当满足非严格递增时记录最大的递增数

s = input()
length,max_length,last=0,0,'0'
for i in s:
if '0'<=i<='9':
if i >= last:
length += 1
max_length = max(max_length,length)
last = i
else:
length = 1
last = i
else:
length = 0
last = '0'
print(max_length)

五、输出这个数列的第n项结果,数列中a[n+1]都是a[n]的描述

描述:一个数列a[N] (N=60),从a[0]开始,每一项都是一个数字。数列中a[n+1]都是a[n]的描述。其中a[0]=1
规则如下:
a[0]:1
a[1]:11(含义:其前一项a[0]=1是1个1,即“11”表示a[0]从左到右,连续出现了1次“1”)
a[2]:21(含义:其前一项a[1]=11,从左到右:是由两个1组成,即21。表示a[1]从左到右,连续出现了两次“1")
a[3]:1211(含义:其前一项a[2]=21,从左到右:是由一个2和一个1组成,即“1211”。表示a[2]从左到右,连续出现了1次“2”,然后又连续出现了1次“1”)
a[4]:111221(含义:其前一项a[3]=1211,从左到右:是由一个1、一个2、两个1组成,即111221。表示a[3]从左到右,连续出现了1次“1”,连续出现了1次“2”,连续出现了两次“1”)
请输出这个数列的第n项结果(a[n],0≤n≤59)。

示例:
输入描述
数列的第n项(0≤n≤59):
4
输出描述:
数列的内容:
111221

n = int(input())
lst = ["1"]
def solution(sr):
sr2= sr+"A"
sr=""
count=0
for i in range(len(sr2)-1):
count +=1
if sr2[i] != sr2[i+1]:
sr = sr +str(count)+sr2[i]
count = 0
return sr
for i in range(n):
lst.append(solution(lst[-1]))
print(lst[n])

六、计算多维数组中最大子矩阵内所有数字的和

描述:定一个二维整数矩阵,要在这个矩阵中选出一个子矩阵,使得这个子矩阵内所有的数字和尽量大,我们把这个子矩阵称为和最大矩阵,子矩阵的选取原则是原矩阵中一块连续的矩形区域,单独一行、单独一列、整个矩阵,都算子矩阵。
输入:
输入的第一行包含2个整数n,m(1<=n,m<=10),表示一个n行m列矩阵,下面有n行,每行m个整数,同一行中,每两个数字之间一个空格,最后一个数字后没有空格,所有数字的取值范围为**[-1000,1000]**

输出:
输出一行,一个数字,表示选出的和最大子矩阵内所有数字的和。

示例:
# input
3 3
951 589 39
-583 -710 473
-229 501 -594
# output
1579

a,b = list(map(int,input().split()))
res =[]
max_sub=0
for _ in range(a):
res.append(list(map(int,input().split())))
for i in range(a+1):
for k in range(i+1,a+1):
for j in range(b+1):
for s in range(j+1,b+1):
temp_sub = sum([sum(temp[j:s]) for temp in res[i:k]])
if temp_sub > max_sub:
max_sub = temp_sub
print(max_sub)

七、还原一个已经打乱顺序的喊7游戏的数组

描述:喊7是一个传统的聚会游戏,N个人围成一圈,按顺时针从1到N编号。编号为1的人从1开始喊数,下一个人喊的数字为上一个人的数字加1,但是当数字是7的倍数或者数字本身含有7的话,要喊"过"。现给定一个长度为N的数组,存储了打乱顺序的每个人喊"过"的次数,请把它还原成正确的顺序,即数组的第i个元素存储编号i的人喊"过"的次数。
输入
输入为一行,为空格分隔的喊"过"的次数

示例:
样例输入
0 1 0
样例输出
1 0 0
输入
0 0 0 2 1
输出
0 2 0 1 0

解析:记录喊7的总量后,初始化喊7的数字,并从头开始推算喊7 的数组

nums = list(map(int,input().split()))
k,index,count=0,1,0
n=len(nums)
out_list=[0]*n
for i in nums:
k += i
while count < k:
if str(index).find("7")!=-1 or index % 7 ==0:
i = (index%n)-1
count +=1
out_list[i]+=1
index +=1
print(" ".join([str(x) for x in out_list]))

八、计算满足GPU算力的一组任务组的最少耗时

描述:为了充分发挥GPU算力,需要尽可能多的将任务交给GPU执行现在有一个任务数组,数组元素表示在这1s内新增的任务个数,且每秒都有新增任务。假设GPU最多一次执行n个任务,一次执行耗时1s,在保证GPU不空闲的情况下,最少需要多长时间执行完成。

输入描述:
第一个参数为GPU最多执行的任务个数,取值范围1~10000
第二个参数为任务数组的长度,取值范围1~10000
第三个参数为任务数组,数字范围1~1000
输出描述:
执行完所有任务需要多少秒
示例:
输入:
3
5
1 2 3 4 5
输出:
6
说明:
一次最多执行3个任务 最少耗时6s
输入:
4
5
5 4 1 1 1
输出:
5

n = int(input())
len = int(input())
l = list(map(int,input().split()))
time,more=0,0
for i in l:
if i+more > n:
more = i+more-n
else:
more = 0
time += 1
while more > 0:
more -= n
time += 1
print(time)

十一、计算字符串中连续出现次数第k多的字母的次数

描述:定一个字符串,只包含大写字母,求在包含同一字母的子串中,长度第 k 长的子串的长度,相同字母只取最长的那个子串。
输入描述: 第一行有一个子串(1<长度<=100),只包含大写字母。 第二行为 k的值 输出描述: 输出连续出现次数第k多的字母的次数。
示例1
输入
AAAAHHHBBCDHHHH
3
输出
2 说明 :同一字母连续出现的最多的是A和H,四次;第二多的是H,3次,但是H已经存在4个连续的,故不考虑;下个最长子串是BB,所以最终答案应该输出2。
示例2
输入
AABAAA
2
输出
1 说明 同一字母连续出现的最多的是A,三次;第二多的还是A,两次,但A已经存在最大连续次数三次,故不考虑;下个最长子串是B,所以输出1
示例3
输入
ABC
4
输出
-1 说明 只含有3个包含同一字母的子串,小于k,输出-1
示例4
输入
ABC
2
输出
1

s, k, count, d = input(), int(input()), 1, {}
n = len(s)
if n != 1:
for i in range(n - 1):
if s[i] == s[i + 1]:
count += 1
else:
d[s[i]] = max(d.get(s[i], 0), count)
count = 1
if i == n - 2:
d[s[i + 1]] = max(d.get(s[i + 1], 0), count)
a = sorted(d.items(), key=lambda x: x[1])
print(-1 if k > len(a) else a[-k][1])
else:
print(1 if k == 1 else -1)

十二、计算一个整数可以由连续的自然数之和的各种情况

描述:一个整数可以由连续的自然数之和来表示
给定一个整数
计算该整数有几种连续自然数之和的表达式
并打印出每一种表达式

输入描述
一个目标整数t 1<= t <=1000
输出描述
1.该整数的所有表达式和表达式的个数
如果有多种表达式,自然数个数最少的表达式优先输出
2.每个表达式中按自然数递增输出

具体的格式参见样例
在每个测试数据结束时,输出一行"Result:X"
其中X是最终的表达式个数

示例:

输入
9
输出
9=9
9=4+5
9=2+3+4
Result:3

n = int(input())
res = [[n]]
for i in list(range(n//2+1))[::-1]:
i+=1
if sum(range(n+1))<n:
break
else:
sum_ = 0
tmp = []
for j in list(range(i))[::-1]:
j+=1
sum_+=j
tmp.append(j)
if sum_== n:
res.append(tmp)
break
elif sum_ > n:
break
for i in res:
print(str(n)+"="+"+".join(map(str,sorted(i))))
print("Result:"+str(len(res)))

九、给定一个正整数数组,计算满足 A = B + 2C的数组序列

描述:定一个正整数数组,检查数组中是否存在满足规则的数字组合
规则: A = B + 2C
输入描述:

第一行输出数组的元素个数。
接下来一行输出所有数组元素,用空格隔开。
输出描述:
如果存在满足要求的数,在同一行里依次输出规则里A/B/C的取值,用空格隔开。
如果不存在,输出0。

示例:
4
2 7 3 0
输出:
7 3 2
说明
7 = 3 + 2 * 2
输入:
3
1 1 1
输出:
0

解析:使用itertools工具类permutations方法生成所有全长排列并直接用于计算

import itertools
n,nums,flag=int(input()),list(map(int,input().split())),True
for a,b,c in itertools.permutations(nums,3):
if a == b + c * 2:
print(a,b,c)
flag = False
if flag:
print(0)

十、根据 Tag Length Value格式解码TLV编码

描述:TLV编码是按 Tag Length Value格式进行编码的 一段码流中的信元用tag标识,tag在码流中唯一不重复 length表示信元value的长度 value表示信元的值
码流以某信元的tag开头 ,tag固定占一个字节,length固定占两个字节,字节序为小端序。

示例:

输入:
31
32 01 00 AE 90 02 00 01 02 30 03 00 AB 32 31 31 02 00 32 33 33 01 00 CC
输出
32 33

k = input()
s = input().split()
n = len(s)
i = 0
while i < len(s):
tag = s[i]
length = int(s[i+2]+s[i+1],16)
value = ""
for j in range(length):
value += s[i+3+j]+" "
i += 3 + length
if k == tag:
print(value)

python(牛客)试题解析3 - 困难的更多相关文章

  1. python(牛客)试题解析1 - 入门级

    导航: 一.NC103 反转字符串 二.NC141 判断是否为回文字符串 三.NC151 最大公约数 四.NC65 斐波那契数列 - - - - - - - - - - 分-割-线 - - - - - ...

  2. python 牛客网 你的输出为:空。请检查一下你的代码,有没有循环输入处理多个case。问题解决

    你的输出为:空.请检查一下你的代码,有没有循环输入处理多个case.点击查看如何处理多个case 核心:他这个程序测试正确与否的流程是 连续输入多组测试数据进行测试,只有每组数据都对才行 所以必须使用 ...

  3. 牛客网华为机试题之Python解法

    牛客网华为机试题之Python解法 第1题 字符串最后一个单词的长度 a = input().split(" ") print(len(a[-1])) 第2题 计算字符个数 a = ...

  4. Python 最常见的 170 道面试题解析:2019 最新

    Python 最常见的 170 道面试题解析:2019 最新 2019年06月03日 23:30:10 GitChat的博客 阅读数 21329 文章标签: PythonPython入门Python面 ...

  5. 【Java笔试】OYO校招Java工程师|牛客平台,算法:字符串翻转。附选择题解析

    文章目录 1.Java笔试算法题:字符串翻转 2.单选题: 2.1.同一进程下的多个线程可以共享哪一种资源:data section 2.2.一个树形的叶结点在前序遍历和后序遍历下,可以相同的相对位置 ...

  6. 算法题14 小Q歌单,牛客网,腾讯笔试题

    算法题14 小Q歌单,牛客网,腾讯笔试题 题目: 小Q有X首长度为A的不同的歌和Y首长度为B的不同的歌,现在小Q想用这些歌组成一个总长度正好为K的歌单,每首歌最多只能在歌单中出现一次,在不考虑歌单内歌 ...

  7. 算法题16 贪吃的小Q 牛客网 腾讯笔试题

    算法题16 贪吃的小Q 牛客网 腾讯笔试题 题目: 链接:https://www.nowcoder.com/questionTerminal/d732267e73ce4918b61d9e3d0ddd9 ...

  8. MySql面试题、知识汇总、牛客网SQL专题练习

    点击名字直接跳转到链接: Linux运维必会的100道MySql面试题之(一) Linux运维必会的100道MySql面试题之(二) Linux运维必会的100道MySql面试题之(三) Linux运 ...

  9. 牛客网数据库SQL实战解析(51-61题)

    牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...

  10. 牛客网数据库SQL实战解析(41-50题)

    牛客网SQL刷题地址: https://www.nowcoder.com/ta/sql?page=0 牛客网数据库SQL实战解析(01-10题): https://blog.csdn.net/u010 ...

随机推荐

  1. Containerd教程

    文档是从B站有关视频上对应找到的,具体视频地址是:https://www.bilibili.com/video/BV1XL4y1F7QB?p=21&spm_id_from=333.880.my ...

  2. Kubernetes中使用ClusterDNS进行服务发现

    在k8s集群中,服务是运行在Pod中的,Pod的发现和副本间负载均衡是我们面临的问题.我们使用Service解决了负载均衡的问题,但是集群环境中,service经常伴随着ip的变动而变动,得益于kub ...

  3. k8s上安装安装 Ingress Controller &卸载

    在 master 节点上执行 nginx-ingress.yaml文件内容 # 如果打算用于生产环境,请参考 https://github.com/nginxinc/kubernetes-ingres ...

  4. 记录阿里云安全组设置遇到的奇葩问题--出口ip

    之前公司使用的路由器里使用的是PPPOE拨号的形式上网的,根据拨号后得到的ip地址,配置到阿里云的安全组里,具体来说是配置到22端口里,也就是说只有特定ip才能访问22端口,也即是说只允许公司网络远程 ...

  5. 我的 Kafka 旅程 - Producer

    原理阐述 Producer生产者是数据的入口,它先将数据序列化后于内存的不同队列中,它用push模式再将内存中的数据发送到服务端的broker,以追加的方式到各自分区中存储.生产者端有两大线程,以先后 ...

  6. C++自学笔记 构造与析构;

    构造与析构 类不是实体:对象属于类:函数属于类 : 用不同的对象调用同一个类里面的函数的时候,函数知道是哪一个对象在调用它 关键字 this this是一个指针 Point a; a.print(); ...

  7. Raft 共识算法

    转载请注明出处:https://www.cnblogs.com/morningli/p/16745294.html raft是一种管理复制日志的算法,raft可以分解成三个相对独立的子问题: 选主(L ...

  8. Python中list列表的常见操作

    Python的list是一个列表,用方括号包围,不同元素间用逗号分隔. 列表的数据项不需要具有相同的类型.(列表还可以嵌套,即列表中的列表) 每个元素都有一个索引(表示位置),从0开始:可以用索引-1 ...

  9. MatrixOne从入门到实践03——部署MatrixOne

    MatrixOne从入门到实践--部署MatrixOne 前两章节我们简单介绍了MatrixOne和源码编译了MatrixOne.本章节将使用不同的部署方式,来部署MatrixOne的服务. 注意:不 ...

  10. mysql 过程和函数语法学习笔记

    CREATE DEFINER=`root`@`%` PROCEDURE `test`(`num` int) BEGIN /*定义变量*/ DECLARE sex TINYINT(2) DEFAULT ...