반응형
스택을 이용하여 푸는문제
나처럼 알고리즘 공부를 시작하는 알린이용 문제다. 자바에서 기본으로 지원해주는 Stack을 이용했다.
1.첫줄에 입력되는 정수k를 받아준다
2.for문으로 k횟수만큼 반복한다.
3.Int타입의 변수number를 이용해 정수를 받아준다.
4.if문을 이용해 3에서 받아준 정수가 0일경우 Stack의 pop 을 0을 제외하고는 push(number)을 해준다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Stack;
public class Main {
public static void main(String[] args) throws IOException{
int sum = 0;
Stack<Integer> stack = new Stack<>();
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
for (int i = 0; i<N; i++){
int number = Integer.parseInt(br.readLine());
if (number==0){
stack.pop();
}else {
stack.push(number);
}
}
for (int i : stack){
sum += i;
}
System.out.println(sum);
}
}
|
cs |
반응형
'알고리즘 > 백준(BAEKJOON)' 카테고리의 다른 글
[자바]스택 /9012번 : 괄호 [백준] (0) | 2022.01.10 |
---|---|
[자바]1181 단어 정렬[백준] (0) | 2022.01.06 |
[백준]10828 스택 /자바/JAVA (0) | 2021.11.03 |
[JAVA] 백준 2750 수 정렬하기 (0) | 2021.10.12 |
백준 1차원배열/4344 자바/평균은 넘겠지 (0) | 2021.09.29 |