最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(wǎng) 會(huì)員登陸 & 注冊(cè)

LeetCode 2134. Minimum Swaps to Group All 1's Together II

2023-04-23 17:00 作者:您是打尖兒還是住店呢  | 我要投稿

A?swap?is defined as taking two?distinct?positions in an array and swapping the values in them.

A?circular?array is defined as an array where we consider the?first?element and the?last?element to be?adjacent.

Given a?binary?circular?array?nums, return?the minimum number of swaps required to group all?1's present in the array together at?any location.

?

Example 1:

Input: nums = [0,1,0,1,1,0,0]

Output: 1

Explanation:?

Here are a few of the ways to group all the 1's together:?

[0,0,1,1,1,0,0] using 1 swap.?

[0,1,1,1,0,0,0] using 1 swap.?

[1,1,0,0,0,0,1] using 2 swaps (using the circular property of the array).?

There is no way to group all 1's together with 0 swaps.?

Thus, the minimum number of swaps required is 1.

Example 2:

Input: nums = [0,1,1,1,0,0,1,1,0]

Output: 2

Explanation: Here are a few of the ways to group all the 1's together:?

[1,1,1,0,0,0,0,1,1] using 2 swaps (using the circular property of the array).?

[1,1,1,1,1,0,0,0,0] using 2 swaps. There is no way to group all 1's together with 0 or 1 swaps. Thus, the minimum number of swaps required is 2.

Example 3:

Input: nums = [1,1,0,0,1]

Output: 0

Explanation: All the 1's are already grouped together due to the circular property of the array. Thus, the minimum number of swaps required is 0.

?

Constraints:

  • 1 <= nums.length <= 105

  • nums[i]?is either?0?or?1.

因?yàn)槭黔h(huán)形數(shù)組,所以只要判斷每個(gè)index開(kāi)始,內(nèi)部有多少個(gè)1就行,依次存儲(chǔ),最后返回sum-max即可;

題目不太難,但是跑出來(lái)時(shí)間太慢了,肯定還有更好的方法;

下面是代碼:

Runtime:?50 ms, faster than?5.12%?of?Java?online submissions for?Minimum Swaps to Group All 1's Together II.

Memory Usage:?61 MB, less than?5.12%?of?Java?online submissions for?Minimum Swaps to Group All 1's Together II.


LeetCode 2134. Minimum Swaps to Group All 1's Together II的評(píng)論 (共 條)

分享到微博請(qǐng)遵守國(guó)家法律
科技| 普宁市| 东方市| 西乌| 册亨县| 抚顺市| 久治县| 山西省| 井研县| 东乡族自治县| 天柱县| 连山| 大城县| 黄山市| 化隆| 固原市| 武山县| 丽水市| 东乌珠穆沁旗| 古蔺县| 弥渡县| 承德市| 西丰县| 镇赉县| 铁力市| 嘉黎县| 屏山县| 资源县| 乌拉特前旗| 新建县| 江城| 龙南县| 井冈山市| 特克斯县| 台中县| 漯河市| 迭部县| 铜梁县| 西乌珠穆沁旗| 乳源| 涟源市|