【牛客刷題記錄】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.pswp.cn/news/452250.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/452250.shtml
英文地址,請注明出處:http://en.pswp.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;…