티스토리 뷰
#include <stdio.h>
#include <iostream>
using namespace std;
int max_score(int a, int b)
{
return a > b ? a : b;
}
int main(void){
int stair_num; // 계단수 변수
int stair_score[301] = {}; // 계단수 300
int store[301] = {}; // 계단 저장 배열 변수(dp)
scanf("%d", &stair_num); // 계단수 입력
// 계단 점수 입력
for (int i = 1; i <= stair_num; i++){
scanf("%d", &stair_score[i]);
}
store[1] = stair_score[1];
//계단을 한번 밟았다고 생각하였을때 값 dp값 저장
if(stair_num >= 2){
store[2] = store[1]+stair_score[2];
}
for(int i=3; i<=stair_num; i++){
// 계단이 한번연속인 경우 - N계단 N-1번째 계단 생각 X , N-2번째 계단의 총점 생각
// 계단이 두번연속인 경우 - N계단 2번 연속일 경우 N-1계단은 밟아야함 , N-2밟아버리면 규칙어긋나버림(최대가 될수없음) , N-3 계단까지 얻은 점수 합
store[i] = max_score(store[i-2]+stair_score[i],store[i-3]+stair_score[i-1]+stair_score[i]);
}
printf("%d\n", store[stair_num]);
}
'Algorithm' 카테고리의 다른 글
[알고리즘] 시간복잡도(Time Complexity)와 공간복잡도(Space Complexity) (0) | 2018.08.19 |
---|---|
[알고리즘] 1937번 백준알고리즘 욕심쟁이 판다 (0) | 2018.08.13 |
[알고리즘] 11052번 백준 알고리즘붕어빵 판매하기 (0) | 2018.08.13 |
[알고리즘] DP(Dynamic Progamming) 동적 계획법 / 피보나치수열 (0) | 2018.08.13 |
[알고리즘] 백준알고리즘 1012 단지번호 붙이기 (0) | 2018.08.11 |
- Total
- Today
- Yesterday
- 초보자를 위한 C언어 300제
- 감자개발자
- Android
- Controller
- 코드엔진
- 노드
- BFS
- 복습
- programming
- 백준알고리즘
- db
- node.js
- 알고리즘
- C langauge
- 텐서플로우
- 학교
- 스프링
- 백준
- 프로그래밍
- 감자코딩
- 머신러닝
- C언어
- Algorigm
- Spring
- TensorFlow
- 개발하는 관광이
- 리버싱
- 안드로이드
- node
- MVC
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 30 | 31 |