【牛客刷题记录】2021-03-10

牛客代码刷题记录1

问题一
  1. 给定一个数组序列, 需要求选出一个区间, 使得该区间是所有区间中经过如下计算的值最大的一个: 区间中的最小数 * 区间所有数的和最后程序输出经过计算后的最大值即可,不需要输出具体的区间。如给定序列 [6 2 1]则根据上述公式, 可得到所有可以选定各个区间的计算值:
    [6] = 6 * 6 = 36;
    [2] = 2 * 2 = 4;
    [1] = 1 * 1 = 1;
    [6,2] = 2 * 8 = 16;
    [2,1] = 1 * 3 = 3;
    [6, 2, 1] = 1 * 9 = 9;
    从上述计算可见选定区间 [6] ,计算值为 36,则程序输出为 36。 区间内的所有数字都在[0, 100]的范围内;

输入输出
  • 输入描述:
    第一行输入点集的个数 N, 接下来 N 行,每行两个数字代表点的 X 轴和 Y 轴。
    对于 50%的数据, 1 <= N <= 10000;
    对于 100%的数据, 1 <= N <= 500000;
  • 输出描述:
    输出“最大的” 点集合, 按照 X 轴从小到大的方式输出,每行两个数字分别代表点的 X 轴和 Y轴。
  • 输入例子1:
    5
    1 2
    5 3
    4 6
    7 5
    9 0
  • 输出例子1:
    4 6
    7 5
    9 0
解决方案:
  • 理解:
    如果x满足P中任意点都不在x的右上方区域内(横纵坐标都大于x),则称其为“最大的”-> 不存在任何点其横纵坐标都大于点x ->
  • 分析:
    1.对所有点x轴进行降序排序,则第一个点一定是最大点
    2.后面的点要想成为最大点,只需其y值大于前面的最大的y值即可
    3.最后倒序输出数组
if __name__ == "__main__":n = int(input())
# 二维数组输入方式a = []for _ in range(n):  # ’_’作用同i,循环标志a.append(list(map(int, input().split())))a.sort(key=lambda x: x[0])j = len(a) - 2tmpy = a[-1][1]for i in range(len(a) - 1, -1, -1):if tmpy < a[i][1]:tmpy = a[i][1]a[j] = a[i]j -= 1for k in range(j + 1, len(a)):print(a[k][0], a[k][1])

函数/方法

  • n=int(input(“[输入]>”))
    input()返回是一个字符串,int(input())把input()返回的字符串转换成整型,返回的是整型
  • str.split(str="", num=string.count(str)
    #通过指定分隔符对字符串进行切片,如果参数 num 有指定值,则分隔 num+1 个子字符串,返回分割后的字符串列表。
    str = “Line1-abcdef \nLine2-abc \nLine4-abcd”;
    print str.split( ); # 默认以空格为分隔符,包含 \n \t
    print str.split(’ ', 1 ); # 以空格为分隔符,分隔成两个
  • map()
    根据提供的函数对指定序列做映射。map(function, iterable, …),第一个参数 function 以参数序列中的每一个元素调用function函数,返回包含每次 function函数返回值的新列表。
    map(lambda x: x ** 2, [1, 2, 3, 4, 5]) # 使用 lambda 匿名函数
    [1, 4, 9, 16, 25]
  • list()方法
    list(tuple) 将元组转换为列表。
    注:元组与列表非常类似,区别在于元组的元素值不能修改,元组是放在括号()中,列表是放于方括号[]中。
    aTuple = (123, ‘runoob’, ‘google’, ‘abc’)
    aList = list(aTuple)
    print ("列表元素 : ")
    print(aList)
    列表元素 : [123, ‘runoob’, ‘google’, ‘abc’]
  • list.sort()
    sort(cmp = None ,key = None, reverse = False) 函数用于对原列表进行排序,如果指定参数,则使用比较函数指定的比较函数。没有返回值,但是会对列表的对象进行排序。
    cmp:可选参数, 如果指定了该参数会使用该参数的方法进行排序。
    key:可选参数,主要是用来进行比较的元素,只有一个参数,具体的函数的参数就是取自于可迭代对象中,指定可迭代对象中的一个元素来进行排序。
    reverse:排序规则,reverse = True 降序, reverse = False 升序(默认)。
    list.sorted()有返回值,返回对key值排好序的list
问题二
  1. 给定一个数组序列, 需要求选出一个区间, 使得该区间是所有区间中经过如下计算的值最大的一个: 区间中的最小数 * 区间所有数的和最后程序输出经过计算后的最大值即可,不需要输出具体的区间。如给定序列 [6 2 1]则根据上述公式, 可得到所有可以选定各个区间的计算值:
    [6] = 6 * 6 = 36;
    [2] = 2 * 2 = 4;
    [1] = 1 * 1 = 1;
    [6,2] = 2 * 8 = 16;
    [2,1] = 1 * 3 = 3;
    [6, 2, 1] = 1 * 9 = 9;
    从上述计算可见选定区间 [6] ,计算值为 36,则程序输出为 36。 区间内的所有数字都在[0, 100]的范围内;
输入输出
  • 输入描述:
    第一行输入数组序列长度n,第二行输入数组序列。
    对于 50%的数据, 1 <= n <= 10000;
    对于 100%的数据, 1 <= n <= 500000;

  • 输出描述:
    输出数组经过计算后的最大值。

  • 输入例子1:
    3
    6 2 1

  • 输出例子1:
    36

思路

遍历每个数,并找出该数的最大区间,即该数在区间中最小,加总求积

if __name__ == "__main__":n = int(input())a = list(map(int, input().split()))ans = 0for i in range(n):tmp = a[i]l = r = iif tmp == 0:continuewhile l - 1 >= 0 and a[l - 1] >= tmp:l = l - 1while r + 1 < n and a[r + 1] >= tmp:r = r + 1ans= max(ans, tmp * sum(a[l: r + 1]))print(ans)
  • continue 语句跳出本次循环,而break跳出整个循环。
    continue 语句用来告诉Python跳过当前循环的剩余语句,然后继续进行下一轮循环,用在while和for循环中。

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

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

相关文章

SpringMVC详细示例实战教程

一、SpringMVC基础入门&#xff0c;创建一个HelloWorld程序 1.首先&#xff0c;导入SpringMVC需要的jar包。 2.添加Web.xml配置文件中关于SpringMVC的配置 123456789101112131415<!--configure the setting of springmvcDispatcherServlet and configure the mapping-->&…

学成在线--8.Freemarker入门教程

文章目录1.FreeMarker介绍1&#xff09;常用的java模板引擎还有哪些&#xff1f;2&#xff09;freemarker是一个用Java开发的模板引擎3&#xff09;模板数据模型输出2.FreeMarker快速入门1&#xff09;创建测试工程2&#xff09;配置文件3&#xff09;创建模型类4&#xff09;创…

面向对象建模

用面向对象方法开发软件&#xff0c;通常需要建立3种形式的模型&#xff0c;它们分别是 描述系统数据结构的对象模型 &#xff0c; 描述系统控制结构的动态模型 和 描述系统功能的功能模型 。一个典型的软件系统使用数据结构(对象模型)&#xff0c;执行操作(动态模型)&#xff…

if...elif...else...fi和case...esac的脚本条件判断式

注意1&#xff1a; if 表达式和case 表达式的区别及什么时候使用哪个要有明确的区分&#xff1f; 『 if .... then .... fi 』对于变量的判断是以『比对』的方式来分辨的&#xff0c; 如果符合状态就进行某些行为&#xff0c;并且透过较多层次 (就是elif ) 的方式来进行多个变量…

安卓自定义View进阶-分类与流程

自定义View绘制流程函数调用链(简化版) 一.自定义View分类 我将自定义View分为了两类(sloop个人分类法&#xff0c;非官方)&#xff1a; 1.自定义ViewGroup 自定义ViewGroup一般是利用现有的组件根据特定的布局方式来组成新的组件&#xff0c;大多继承自ViewGroup或各种Layout&…

【笔试记录】2021/3/13美团

2021/3/13美团笔试 1.旋转二维数组 m, n map(int, input().split()) a [] for _ in range(m):a.append(list(map(int, input().split()))) for j in range(n):for k in range(m):print(a[k][j], end )print(end\n)输入输出 2.找出输入字符串中的所有数字 s input() n …

Ubuntu品牌机批量涌入世界市场,中国不会例外

根据种种信息来源&#xff0c;我们可以预见&#xff1a; Ubuntu 品牌机不久即将涌入世界市场&#xff0c;中国也不会例外。对此现象&#xff0c;我们必须有一定的思想准备。 2004年4月&#xff0c;在澳大利亚一次学术会议上萌发了Ubuntu发行版的念头&#xff0c;至今已经有8个年…

学成在线--9.页面静态化

文章目录一.页面静态化流程二.数据模型1.轮播图DataUrl接口1&#xff09;需求分析2&#xff09;接口定义3&#xff09;Dao4&#xff09;Service5&#xff09;Controller6&#xff09;测试2.远程请求接口1&#xff09;添加依赖2&#xff09;配置RestTemplate3&#xff09;测试Re…

数据库的完整性和安全性

数据的完整性防止数据库中存在不符合语义的数据&#xff0c;也就是防止数据库中存在不正确的数据防范对象&#xff1a;不合语义的、不正确的数据数据的安全性保护数据库 防止恶意的破坏和非法的存取防范对象&#xff1a;非法用户和非法操作

数据库MySQL/mariadb知识点——日志记录(2)二进制日志

二进制日志 记录已提交事务导致数据改变或潜在导致数据改变的SQL语句&#xff0c;通过“重放”日志文件中的事件来生成数据副本&#xff0c;不依赖存储引擎类型。 开启二进制日志&#xff0c;默认是关闭的&#xff0c;二进制日志和数据分开存放 开启记录二进制文件的功能&#…

【面试记录】Python常见面试200题及答案总结

Python常见面试200题及答案总结 /待完善/ 1. 列出5个常用python标准库&#xff1f; os&#xff1a;提供了不少与操作系统相关联的函数&#xff0c;提供了一种可移植的使用操作系统功能的方法。使用os模块中提供的接口&#xff0c;可实现跨平台访问。但是&#xff0c;并不是所…

Linux负载均衡软件LVS之一(概念篇)

2019独角兽企业重金招聘Python工程师标准>>> 一、 LVS简介 LVS是Linux Virtual Server的简称&#xff0c;也就是Linux虚拟服务器, 是一个由章文嵩博士发起的自由软件项目&#xff0c;它的官方站点是www.linuxvirtualserver.org。现在LVS已经是 Linux标准内核的一部分…

C语言目录操作 (Linux/Unix)

获得工作目录&#xff1a;#include <unistd.h> char *getcwd(char *buf,size_t size);char *getwd(char *buf);/*this is for FreeBSD*/ 改变当前目录&#xff1a;#include <unistd.h> int chdir(const char *path); 保存当前目录&#xff1a;#include <unist…

学成在线--10.页面预览

文章目录一.需求分析二. 搭建环境1.在cms服务中集成freemarker&#xff1a;2.在application.yml配置freemarker三.Service四.Controller五.页面预览测试-- 配置Nginx代理六.页面预览测试-- 添加“页面预览”链接一.需求分析 页面在发布前增加页面预览的步骤&#xff0c;方便用…

参照完整性违约处理

参照完整性违约处理 &#xff08;1&#xff09; 拒绝&#xff08;NO ACTION&#xff09;执行 不允许该操作执行。该策略一般设置为默认策略 &#xff08;2&#xff09; 级联&#xff08;CASCADE&#xff09;操作 当删除或修改被参照表&#xff08;Student&#xff09;的一个元…

BSON和JSON的区别

BSON目前主要用于MongoDB中&#xff0c;是mongoDB的数据存储格式&#xff0c;BSON基于JSON格式&#xff0c;选择JSON进行改造的原因主要是JSON的通用性及JSON的schemaless的特性。 BSON主要实现下面三点&#xff1a; 1、更快的遍历速度 对json格式来说&#xff0c;太大的json结…

【代码刷题】排序算法总结(python实现)

排序算法总结&#xff08;Python实现&#xff09;算法介绍算法分类相关概念1. 冒泡排序&#xff08;Bubble Sort&#xff09;1.1 思想1.2 python实现1.3 复杂度1.4 稳定性2. 快速排序&#xff08;Quick Sort&#xff09;2.1 思想&#xff08;伪代码&#xff09;2.2 python实现2…

C语言遍历目录

C语言遍历目录&#xff0c;可以循环的遍历子目录#include <stdio.h>#include <string.h>#include <stdlib.h>#include <dirent.h>#include <sys/stat.h>#include <unistd.h>#include <sys/types.h>void listDir(char *path){struct …

学成在线--11.RabbitMQ快速入门

文章目录一.RabbitMQ简介二.相关知识1.AMQP2.JMS是什么 &#xff1f;三.RabbitMQ的工作原理四.Hello World1.创建Maven工程2.生产者3.消费者五.总结一.RabbitMQ简介 MQ全称为Message Queue&#xff0c;即消息队列&#xff0c; RabbitMQ是由erlang语言开发&#xff0c;基于AMQP…

数据库断言

SQL中&#xff0c;可以使用 CREATE ASSERTION语句&#xff0c;通过声明性断言来指定更具一般性的约束。 可以定义涉及多个表的或聚集操作的比较复杂的完整性约束。 断言创建以后&#xff0c;任何对断言中所涉及的关系的操作都会触发关系数据库管理系统对断言的检查&#xff0c;…