牛客NC392 參加會議的最大數目【中等 貪心+小頂堆 Java/Go/PHP 力扣1353】

題目

在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述
題目鏈接:
https://www.nowcoder.com/practice/4d3151698e33454f98bce1284e553651
https://leetcode.cn/problems/maximum-number-of-events-that-can-be-attended/description/

思路

 貪心+優先級隊列

Java代碼

import java.util.*;public class Solution {/*** 代碼中的類名、方法名、參數名已經指定,請勿修改,直接返回方法規定的值即可*** @param meetings int整型ArrayList<ArrayList<>>* @return int整型*/public int attendmeetings (ArrayList<ArrayList<Integer>> meetings) {//貪心+優先級隊列//力扣1353. 最多可以參加的會議數目    力扣上題目描述的更好int ans = 0, max = -1; //max為最后一個會議的結束時間//按會議結束時間排序PriorityQueue<Integer> q = new PriorityQueue<>(new Comparator<Integer>() {@Overridepublic int compare(Integer a, Integer b) {return a - b;}});// key -> 第 i 天, value -> 第 i 天開始的會議的結束時間Map<Integer, List<Integer>> map = new HashMap<>();for (ArrayList<Integer> e : meetings) {//將開始時間相同的所有會議的結束時間放一起if (!map.containsKey(e.get(0))) {map.put(e.get(0), new ArrayList<>());}map.get(e.get(0)).add(e.get(1));//max為最后一個會議的會議結束時間max = Math.max(e.get(1), max);}// 整體思路就是從1開始到最晚結束時間依次遍歷一遍,然后挑選此時間要進行的會議;// 而隊列的作用就是存儲未進行的會議;挑選的判斷條件就是挑選的時間不能小于此時的時間,// 因為隊列中存儲的是每個會議最晚進行時間,即,結束時間for (int i = 1; i <= max ; i++) {if (map.containsKey(i)) {for (Integer cur : map.get(i)) {q.add(cur);}}while (!q.isEmpty() && q.peek() < i) {q.poll();}if (!q.isEmpty()) {ans++;q.poll();}}return ans;}
}

Go代碼

package main/*** 代碼中的類名、方法名、參數名已經指定,請勿修改,直接返回方法規定的值即可*** @param meetings int整型二維數組* @return int整型*/
func attendmeetings(meetings [][]int) int {//貪心+優先級隊列//自己實現的升序堆,按meetings里的結束時間排序h := Heap{make([]int, 10), 0}lastday := -1 //最后會議結束時間//key: 會議開始是第key天,開始時間的相同的會議的結束時間放同個一list中daymap := map[int][]int{}for _, e := range meetings {start := e[0]end := e[1]_, ok := daymap[start]if !ok {daymap[start] = []int{}}daymap[start] = append(daymap[start], end)if lastday < end {lastday = end}}ans := 0// 整體思路就是從1開始到最晚結束時間依次遍歷一遍,然后挑選此時間要進行的會議;// 而隊列的作用就是存儲未進行的會議;挑選的判斷條件就是挑選的時間不能小于此時的時間,// 因為隊列中存儲的是每個會議最晚進行時間,即,結束時間for i := 1; i <= lastday; i++ {_, ok := daymap[i]if ok {list := daymap[i]for _, v := range list {h.add(v)}}for h.Size > 0 && h.peek() < i {h.remove()}if h.Size > 0 {ans++h.remove()}}return ans
}type Heap struct {Arr  []intSize int
}func (h *Heap) ensure(length int) { //堆的擴容old := len(h.Arr)if old >= length {return}newSize := old + old>>1newArr := make([]int, newSize)for i := 0; i < old; i++ {newArr[i] = h.Arr[i]}h.Arr = newArr
}func (h *Heap) add(x int) { //往堆中添加元素idx := h.Sizeh.ensure(idx + 1)h.Arr[idx] = xh.shiftup(idx)h.Size++
}func (h *Heap) shiftup(idx int) { //堆的上濾base := h.Arr[idx]for idx > 0 {pid := (idx - 1) >> 1parent := h.Arr[pid]if base >= parent {break}h.Arr[idx] = parentidx = pid}h.Arr[idx] = base
}func (h *Heap) peek() int {return h.Arr[0]
}func (h *Heap) remove() int {ans := h.Arr[0]idx := h.Sizeh.Arr[0] = h.Arr[idx-1]h.shiftdown(0)h.Size--return ans
}func (h *Heap) shiftdown(idx int) { //下竄,其實可以不傳idx,默認是0,從0下標下竄base := h.Arr[idx]half := h.Size >> 1for idx < half {cidx := idx<<1 + 1right := cidx + 1child := h.Arr[cidx]if right < h.Size && h.Arr[right] < child {cidx = rightchild = h.Arr[right]}if base < child {break}h.Arr[idx] = childidx = cidx}h.Arr[idx] = base
}

PHP代碼

<?php/*** 代碼中的類名、方法名、參數名已經指定,請勿修改,直接返回方法規定的值即可** * @param meetings int整型二維數組 * @return int整型*/
function attendmeetings( $meetings )
{//貪心+優先級隊列$ans = 0;$max = -1; //會議日期最大的那個日期,從每場會議的結束日期里獲取$h = new Heap();//key: 會議的開始日期start,value:存結束時間的集合list,相同的start的集合$map = [];foreach ($meetings as $e){$start = $e[0];$end = $e[1];if(!isset($map[$start])){$map[$start] =[];}$map[$start][count($map[$start])] = $end;if($max < $end){$max = $end;}}// 整體思路就是從1開始到最晚結束時間依次遍歷一遍,然后挑選此時間要進行的會議;// 而隊列的作用就是存儲未進行的會議;挑選的判斷條件就是挑選的時間不能小于此時的時間,// 因為隊列中存儲的是每個會議最晚進行時間,即,結束時間for($i=1;$i<=$max;$i++){if(isset($map[$i])){$arr = $map[$i];foreach ($arr as $d){$h->add($d);}}while ($h->size >0 && $h->peek() <$i){$h->remove();}if ($h->size >0){$ans++;$h->remove();}}return $ans;
}class Heap{ //自己的實現的升序堆public $arr;public $size;public function __construct(){//初始化堆for($i=0;$i<10;$i++){$this->arr[$i] =0;}$this->size =0;}public function ensure($cap){ //擴容代碼$old = count($this->arr);if($old >=$cap) return;$newsize = $old+$old >>1;$newarr = [];for($i=0;$i<$newsize;$i++){$newarr[$i] =0;if($i<$old){$newarr[$i] = $this->arr[$i];}}$this->arr  =$newarr;}public function add($x){$idx = $this->size;$this->ensure($idx+1);$this->arr[$idx] =$x;$this->shiftup($idx);$this->size++;}public function shiftup($idx){ //上濾$base = $this->arr[$idx];while ($idx >0){$pid = ($idx-1) >> 1; //父id$parent = $this->arr[$pid];if($base >$parent) break;$this->arr[$idx] = $parent;$idx = $pid;}$this->arr[$idx] = $base;}public function peek(){return $this->arr[0];}public function remove(){$ans =$this->arr[0];$curlen = $this->size;$this->arr[0] = $this->arr[$curlen-1];$this->size--;$this->shiftdown(0);return $ans;}//下竄,可以不用傳idx參數,一般是從0開始下竄,idx=0public function shiftdown($idx){$base = $this->arr[$idx];$half = $this->size >> 1;while ($idx<$half) {$cidx = ($idx<<1) +1;$right = $cidx+1;$child = $this->arr[$cidx];if($right < $this->size && $child > $this->arr[$right]){$cidx = $right;$child = $this->arr[$right];}if($child > $base) break;$this->arr[$idx] =$child;$idx= $cidx;}$this->arr[$idx] = $base;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/15641.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/15641.shtml
英文地址,請注明出處:http://en.pswp.cn/web/15641.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java面試高級篇(JVM、Mysql、Redis、Kafka)

文章目錄 面試專題-java高級篇1. JVM有做過jvm的調優嗎?常用的jvm參數調優有哪些?如果jvm持續一段時間頻繁的發生Young GC (輕GC) 可能原因有哪些? 2. Mysql2.1. 基本功(見為知筆記)2.2. 什么是索引2.3. 索引的優劣勢2.4. MySQL的索引結構2.4.1. B-Tree索引2.4.2. BTree索引…

外賣系統源碼開發全攻略:外賣小程序與后臺管理系統的設計與實現

今天&#xff0c;小編將詳細介紹外賣系統源碼的開發全攻略&#xff0c;從需求分析到設計與實現&#xff0c;為開發者提供全面指導。 一、需求分析 1.用戶需求 用戶是外賣系統的核心&#xff0c;需滿足以下基本需求&#xff1a; -瀏覽菜單并下單 -實時追蹤訂單 -多種支付方…

每日一題——博弈論(枚舉與暴力)

博弈論 題目描述 運行代碼 #include<iostream> #include<vector> using namespace std; int main(){int n;cin >> n;vector<int> d(n,0);for(int i 0;i < n;i){cin >> d[i];}vector<int> in(1000,0);for(int k 1;k<3;k){for(int…

ESP32燒錄AT固件并進行MQTT通訊

首先下載AT固件 發布的固件 - ESP32 - — ESP-AT 用戶指南 latest 文檔 下載燒錄工具 下載指導 - ESP32 - — ESP-AT 用戶指南 latest 文檔 燒錄后注意usb的串口是不能發AT指令的 需要用16和17腳 用AT指令確認OK后連WIFI ATCWMODE1 //設置客戶端模式 ATCWLAP …

mysql誤刪后使用binlog恢復數據

1 預期效果 使用 binlog 恢復數據的預期效果是將誤刪的數據還原到誤刪之前的狀態&#xff0c;以減少或消除數據丟失的影響。通過正確解析和執行 binlog 中的操作記錄&#xff0c;可以重新執行誤刪操作之后的插入、更新或刪除操作&#xff0c;從而恢復被誤刪的數據。 數據恢復&…

Cocos Creator 編輯器的數據綁定詳解

Cocos Creator 是一款由 Cocos 平臺推出的游戲開發工具&#xff0c;它集成了圖形化編輯器、腳本引擎和資源管理器等功能&#xff0c;方便開發者快速地創建游戲。其中&#xff0c;數據綁定是 Cocos Creator 編輯器中非常重要的一個功能&#xff0c;它可以幫助開發者實現頁面元素…

三生隨記——山洞之謎

第一章&#xff1a;初識山洞 在遠離人煙的深山之中&#xff0c;隱藏著一個鮮為人知的山洞。這個山洞名叫幽洞&#xff0c;它的名字在當地人的口中帶著一股說不出的詭異和神秘。據說&#xff0c;幽洞深不見底&#xff0c;里面充滿了未知的恐懼和危險。然而&#xff0c;對于好奇心…

Go微服務: Grpc服務注冊在Consul的示例(非Go-Micro)

概述 現在&#xff0c;我們使用consul客戶端的api來把GRPC服務實現注冊到consul上&#xff0c;非Go-Micro的形式其實&#xff0c;consul官方提供了對應的接口調用來實現&#xff0c;golang中的consul/api包對其進行了封裝我們使用consul/api來進行展示 目錄結構 gitee.com/g…

springboot+mysql在線考試系統-計算機畢業設計源碼82584

摘 要 信息化社會內需要與之針對性的信息獲取途徑&#xff0c;但是途徑的擴展基本上為人們所努力的方向&#xff0c;由于站在的角度存在偏差&#xff0c;人們經常能夠獲得不同類型信息&#xff0c;這也是技術最為難以攻克的課題。針對在線考試等問題&#xff0c;對如何通過計算…

Websocket助手

功能介紹 WS助手是WebSocket調試的開發工具&#xff0c;該客戶端工具可以幫助開發人員快速連接到測試/生產環境&#xff0c;它可以幫助您監視和分析 Websocket 消息&#xff0c;并在開發過程中解決問題&#xff1b;可以模擬客戶端實現與服務器的數據交互&#xff0c;并完成批量…

論文精讀:HuggingGPT: Solving AI Tasks with ChatGPT and its Friends in Hugging Face

HuggingGPT: Solving AI Tasks with ChatGPT and its Friends in Hugging Face Status: Reading Author: Dongsheng Li, Kaitao Song, Weiming Lu, Xu Tan, Yongliang Shen, Yueting Zhuang Institution: 微軟亞洲研究院&#xff08;Microsoft Research Asia&#xff09;, 浙江…

uniapp 對接 微信App/支付寶App 支付

相關文檔&#xff1a;uni.requestPayment(OBJECT) | uni-app官網 示例代碼&#xff1a; import qs from qsasync aliPay(){const { provider } await uni.getProvider({ service:payment })if(provider.includes(alipay)){uni.request({url:后端接口地址,data:{ //傳參 },suc…

? 傳知代碼 ? 基于擴散模型的無載體圖像隱寫術

&#x1f49b;前情提要&#x1f49b; 本文是傳知代碼平臺中的相關前沿知識與技術的分享~ 接下來我們即將進入一個全新的空間&#xff0c;對技術有一個全新的視角~ 本文所涉及所有資源均在傳知代碼平臺可獲取 以下的內容一定會讓你對AI 賦能時代有一個顛覆性的認識哦&#x…

前端---閉包【防抖以及節流】----面試高頻!

1.什么閉包 釋放閉包 從以上看出&#xff1a;一般函數調用一次會把內部的數據進行清除--但是這種操作卻可以一起保留局部作用域的數據 // 優點:1、可以讀取函數內部的變量 2、讓這些變量始中存在局部作用域當中 2.閉包產生的兩種業務場景&#xff1a;防抖、節流 2.1防抖 舉…

QGraphicsView實現簡易地圖16『爆炸效果』

前文鏈接&#xff1a;QGraphicsView實現簡易地圖15『測量面積』 一種簡單的爆炸波擴散效果 動態演示效果&#xff1a; 靜態展示圖片&#xff1a; 核心代碼&#xff1a; #pragma once #include "../AbstractGeoItem.h" #include "DataStruct/GeoData.h"…

sysbench壓測mysql性能測試命令和報告

sysbench壓測mysql性能測試命令和報告 一、安裝sysbench工具二、創建測試數據庫三、基于sysbench構造測試表和測試數據四、數據庫性能測試1、數據庫讀寫性能測試2、數據庫讀性能測試3、數據庫刪除性能測試4、數據庫更新索引字段性能測5、數據庫更新非索引字段性能測試6、數據庫…

windows ip助手函數了解

根據手冊,winsock編程中提供的有一類函數叫ip助手函數;比如Ipconfig函數,從名字看應該是可自己編程實現類似ipconfig命令的功能; 剛看到一個示例,是MS提供的,也屬于這一類,代碼如下, #include <winsock2.h> #include <ws2tcpip.h> #include <iphlpapi…

C++ vector類

目錄 0.前言 1.vector介紹 2.vector使用 2.1 構造函數(Constructor) 2.1.1. 默認構造函數 (Default Constructor) 2.1.2 填充構造函數 (Fill Constructor) 2.1.3 范圍構造函數 (Range Constructor) 2.1.4 拷貝構造函數 (Copy Constructor) 2.2 迭代器(Iterator) 2.2.…

十、通配符和正則表達式

10.1 通配符 通配符是由shell處理的, 它只會出現在 命令的“參數”里。當shell在“參數”中遇到了通配符 時&#xff0c;shell會將其當作路徑或文件名去在磁盤上搜尋可能的匹配&#xff1a;若符合要求的匹配存在&#xff0c;則進 行代換(路徑擴展)&#xff1b;否則就將該通配…

python安裝依賴

創建 requirement.txt 文件并填充內容 flask2.0.0 pandas1.3.3 numpy1.21.2 安裝模塊 pip install -r requirement.txt