LeetCode - 283 이동 0 - 배열 (python) (c)
문제 풀이 github
하나의 배열
nums
을 지정 하고 함 수 를 만들어 서 모든 0
을 배열 의 끝으로 이동 시 키 는 동시에 0 요소 가 아 닌 상대 적 인 순 서 를 유지 합 니 다.예시:
: [0,1,0,3,12]
: [1,3,12,0,0]
:
- , 。
- 。
: , , ,
nums【a,b,c,d,e,f,g,h,i,j,k】, l1 l2 = len(nums)-1, l1 l2
l2
l1 ,l2 .
[l2+1,l2+2,,,,,,,l1] nums[l2]=0
l1 - 1 l1 ,l2 。
( l1 , ,l1 l2 )
(python):
class Solution:
def moveZeroes(self, nums):
"""
:type nums: List[int]
:rtype: void Do not return anything, modify nums in-place instead.
"""
pos = 0 #
count = 0
l = len(nums)
l1 = l2 = l - 1
if l == 0:
return
else:
count = nums.count(0)
if count == l: #
return
else:
if count == 0: #
return
else:
while(l2 >= 0):
if nums[l2] == 0:
pos = l1 - l2
for i in range(pos):
nums[l2 + i] = nums[l2 + i + 1]
nums[l1] = 0
l1 -= 1
l2 -= 1
, 。 ( ), 。
class Solution:
def moveZeroes(self, nums: List[int]) -> None:
"""
Do not return anything, modify nums in-place instead.
"""
pre = 0
for post in range(len(nums)):
if nums[post]:
nums[pre], nums[post] = nums[post], nums[pre]
pre += 1
(C): , , C
void moveZeroes(int* nums, int numsSize) {
int j = 0;
for(int i = 0; i < numsSize; i++) {
if(nums[i] != 0) {
nums[j++] = nums[i];
}
}
for(; j < numsSize; j++) {
nums[j] = 0;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
로마 숫자를 정수로 또는 그 반대로 변환그 중 하나는 로마 숫자를 정수로 변환하는 함수를 만드는 것이었고 두 번째는 그 반대를 수행하는 함수를 만드는 것이었습니다. 문자만 포함합니다'I', 'V', 'X', 'L', 'C', 'D', 'M' ; 문자열이 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.