๋ชฉ์ฐจ
๋ฌธ์
์ฌ๋ฌ๋ถ๋ ์๋ค์ํผ ์ฌ๋ฌ๋ถ์ ํ๋ฆฐํฐ ๊ธฐ๊ธฐ๋ ์ฌ๋ฌ๋ถ์ด ์ธ์ํ๊ณ ์ ํ๋ ๋ฌธ์๋ฅผ ์ธ์ ๋ช ๋ น์ ๋ฐ์ ‘์์๋๋ก’, ์ฆ ๋จผ์ ์์ฒญ๋ ๊ฒ์ ๋จผ์ ์ธ์ํ๋ค. ์ฌ๋ฌ ๊ฐ์ ๋ฌธ์๊ฐ ์์ธ๋ค๋ฉด Queue ์๋ฃ๊ตฌ์กฐ์ ์์ฌ์ FIFO - First In First Out - ์ ๋ฐ๋ผ ์ธ์๊ฐ ๋๊ฒ ๋๋ค. ํ์ง๋ง ์๊ทผ์ด๋ ์๋ก์ด ํ๋ฆฐํฐ๊ธฐ ๋ด๋ถ ์ํํธ์จ์ด๋ฅผ ๊ฐ๋ฐํ์๋๋ฐ, ์ด ํ๋ฆฐํฐ๊ธฐ๋ ๋ค์๊ณผ ๊ฐ์ ์กฐ๊ฑด์ ๋ฐ๋ผ ์ธ์๋ฅผ ํ๊ฒ ๋๋ค.
- ํ์ฌ Queue์ ๊ฐ์ฅ ์์ ์๋ ๋ฌธ์์ ‘์ค์๋’๋ฅผ ํ์ธํ๋ค.
- ๋๋จธ์ง ๋ฌธ์๋ค ์ค ํ์ฌ ๋ฌธ์๋ณด๋ค ์ค์๋๊ฐ ๋์ ๋ฌธ์๊ฐ ํ๋๋ผ๋ ์๋ค๋ฉด, ์ด ๋ฌธ์๋ฅผ ์ธ์ํ์ง ์๊ณ Queue์ ๊ฐ์ฅ ๋ค์ ์ฌ๋ฐฐ์น ํ๋ค. ๊ทธ๋ ์ง ์๋ค๋ฉด ๋ฐ๋ก ์ธ์๋ฅผ ํ๋ค.
์๋ฅผ ๋ค์ด Queue์ 4๊ฐ์ ๋ฌธ์(A B C D)๊ฐ ์๊ณ , ์ค์๋๊ฐ 2 1 4 3 ๋ผ๋ฉด C๋ฅผ ์ธ์ํ๊ณ , ๋ค์์ผ๋ก D๋ฅผ ์ธ์ํ๊ณ A, B๋ฅผ ์ธ์ํ๊ฒ ๋๋ค.
์ฌ๋ฌ๋ถ์ด ํ ์ผ์, ํ์ฌ Queue์ ์๋ ๋ฌธ์์ ์์ ์ค์๋๊ฐ ์ฃผ์ด์ก์ ๋, ์ด๋ค ํ ๋ฌธ์๊ฐ ๋ช ๋ฒ์งธ๋ก ์ธ์๋๋์ง ์์๋ด๋ ๊ฒ์ด๋ค. ์๋ฅผ ๋ค์ด ์์ ์์์ C๋ฌธ์๋ 1๋ฒ์งธ๋ก, A๋ฌธ์๋ 3๋ฒ์งธ๋ก ์ธ์๋๊ฒ ๋๋ค.
์ ๋ ฅ
์ฒซ ์ค์ ํ ์คํธ์ผ์ด์ค์ ์๊ฐ ์ฃผ์ด์ง๋ค. ๊ฐ ํ ์คํธ์ผ์ด์ค๋ ๋ ์ค๋ก ์ด๋ฃจ์ด์ ธ ์๋ค.
ํ ์คํธ์ผ์ด์ค์ ์ฒซ ๋ฒ์งธ ์ค์๋ ๋ฌธ์์ ๊ฐ์ N(1 ≤ N ≤ 100)๊ณผ, ๋ช ๋ฒ์งธ๋ก ์ธ์๋์๋์ง ๊ถ๊ธํ ๋ฌธ์๊ฐ ํ์ฌ Queue์์ ๋ช ๋ฒ์งธ์ ๋์ฌ ์๋์ง๋ฅผ ๋ํ๋ด๋ ์ ์ M(0 ≤ M < N)์ด ์ฃผ์ด์ง๋ค. ์ด๋ ๋งจ ์ผ์ชฝ์ 0๋ฒ์งธ๋ผ๊ณ ํ์. ๋ ๋ฒ์งธ ์ค์๋ N๊ฐ ๋ฌธ์์ ์ค์๋๊ฐ ์ฐจ๋ก๋๋ก ์ฃผ์ด์ง๋ค. ์ค์๋๋ 1 ์ด์ 9 ์ดํ์ ์ ์์ด๊ณ , ์ค์๋๊ฐ ๊ฐ์ ๋ฌธ์๊ฐ ์ฌ๋ฌ ๊ฐ ์์ ์๋ ์๋ค.
์ถ๋ ฅ
๊ฐ ํ ์คํธ ์ผ์ด์ค์ ๋ํด ๋ฌธ์๊ฐ ๋ช ๋ฒ์งธ๋ก ์ธ์๋๋์ง ์ถ๋ ฅํ๋ค.
์์ ์ ๋ ฅ
3
1 0
5
4 2
1 2 3 4
6 0
1 1 9 1 1 1
์์ ์ถ๋ ฅ
1
2
5
๋์ ์ฝ๋
case = int(input())
for i in range(case):
volume, targetIdx = tuple(map(int, input().split(' '))) #์๋ฃ๊ฐ์, target
starList = list(map(int, input().split(' '))) #์ค์๋list
if(volume == 1): #์๋ฃ๊ฐ์๊ฐ 1๊ฐ
print(1)
continue;
cnt = 0;
while(True):
if(starList[0] == max(starList)): #0๋ฒ์งธ๊ฐ ์ค์๋ ์ฐ์
cnt += 1 #๋น ์ ธ๋๊ฐ cnt +1
if(targetIdx == 0): #0๋ฒ์งธ๊ฐ target์ผ ๊ฒฝ์ฐ
print(cnt) #cnt ์ถ๋ ฅ
break;
volume -= 1 #๋ฌธ์ ๊ฐ์ -1
targetIdx -= 1 #targetIdx์ ์์ ์๋น๊ธฐ๊ธฐ
starList.pop(0)
continue #๋ค์ ๋ฐ๋ณต
else: #0๋ฒ์งธ๊ฐ ์ค์๋ ์ฐ์X
temp = starList.pop(0)
starList.append(temp)
if(targetIdx == 0): #0๋ฒ์งธ๊ฐ target์ด์์ ๊ฒฝ์ฐ
targetIdx = volume-1 #targetIdx ๋งจ ๋ค๋ก
else:
targetIdx -= 1 #targetIdx ์๋น๊ธฐ๊ธฐ
์ฝ๋ฉํธ
๋์๋ฆฌ ํ๋์ผ๋ก ๋ค์ ์์ํ ๋ฐฑ์ค ๋ฌธ์ ํ์ด!
์๋ฃ๊ตฌ์กฐ ์ค ํ๋์ธ 'ํ'๋ฅผ ๊ตฌํํด๋ณด์๋ค.
ํ์ด์ฌ์ max()ํจ์๋ฅผ ์ด์ฉํด์ ์ฝ๊ฒ ๊ตฌํํ ์ ์์๋ ๊ฒ ๊ฐ๋ค.
'๐ฆ | ์ฝ๋ฉํ ์คํธ ์ฐ์ต > BOJ' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[Python] ๋ฐฑ์ค 1083 ์ํธ (0) | 2022.03.28 |
---|---|
[Python] ๋ฐฑ์ค 1920 ์ ์ฐพ๊ธฐ (0) | 2022.03.28 |
[Python] ๋ฐฑ์ค 10951๋ฒ A+B - 4 (0) | 2022.01.10 |
[Python] ๋ฐฑ์ค 10951๋ฒ A+B - 4 (0) | 2022.01.09 |
[Python] ๋ฐฑ์ค 1152๋ฒ ๋จ์ด์ ๊ฐ์ (0) | 2022.01.09 |
๋๊ธ