日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode 1239. 串联字符串的最大长度

發布時間:2023/11/29 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode 1239. 串联字符串的最大长度 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

題目

二進制手表頂部有 4 個 LED 代表 小時(0-11),底部的 6 個 LED 代表 分鐘(0-59)。每個 LED 代表一個 0 或 1,最低位在右側。

例如,下面的二進制手表讀取 “3:25” 。

(圖源:WikiMedia - Binary clock samui moon.jpg ,許可協議:Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0) )

給你一個整數 turnedOn ,表示當前亮著的 LED 的數量,返回二進制手表可以表示的所有可能時間。你可以 按任意順序 返回答案。

小時不會以零開頭:

例如,“01:00” 是無效的時間,正確的寫法應該是 “1:00” 。
分鐘必須由兩位數組成,可能會以零開頭:

例如,“10:2” 是無效的時間,正確的寫法應該是 “10:02” 。

示例 1:

輸入:turnedOn = 1
輸出:[“0:01”,“0:02”,“0:04”,“0:08”,“0:16”,“0:32”,“1:00”,“2:00”,“4:00”,“8:00”]
示例 2:

輸入:turnedOn = 9
輸出:[]

提示:

0 <= turnedOn <= 10

解題思路

時間由兩個部分組成

  • 小時(0-11)
  • 分鐘(0-59)
    手表當前亮著的 LED 的數量,可以看成是二進制表示中1的個數,
    因此使用兩個二進制數分別表示小時和分鐘,它們二進制表示中的1的個數等于turnedOn
  • 遍歷0-59,使用map記錄二進制中1的個數和對應分鐘的映射,
  • 遍歷0-11,計算當前小時對應的元素已經占用了多少個1,記作cur,那么分鐘只能有turnedOn-cur個1,使用map可以快速找出二進制表示中1的個數為turnedOn-cur的分鐘數,再進行組合。
  • 代碼

    class Solution {public List<String> readBinaryWatch(int turnedOn) {List<String> res=new ArrayList<>();Map<Integer,List<Integer>> min=new HashMap<>();for (int i=0;i<60;i++){int cur=Integer.bitCount(i);if(!min.containsKey(cur))min.put(cur,new ArrayList<>());min.get(cur).add(i);}for (int i=0;i<=11;i++){int cur=Integer.bitCount(i);if(cur>=4||!min.containsKey(turnedOn-cur))continue;List<Integer> mi = min.get(turnedOn-cur);for (int k = 0; k < mi.size(); k++) {res.add(String.format("%d:%02d",i,mi.get(k)));}}return res;} }

    總結

    以上是生活随笔為你收集整理的leetcode 1239. 串联字符串的最大长度的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。