분류 전체보기
19.11.22 (vector 2차 배열 선언, lower bound, upper bound)
2차 배열을 사용하면 함수로 매개변수를 줄 때에 포인터 때문에 머리가 복잡하다. 이를 벡터를 통해 2차 배열을 이용하면 아주 간단히 할 수 있다. vector vp; vp.assign(n,vector(m,0)); 이러면 끝이다. vp.size(); 를 하면 앞의 n 이 나오게된다. vp[i].size() 하면 뒤의 m 저기서 > 이렇게 >>를 붙여쓰면 쉬프트연산으로 착각해버리니 뛰어쓰기를 꼭 사용하자. 줄여서 vectorvp(n,vector(m,0)) 이렇게 사용해도 된다. 0으로 초기화 까지 한 것이다. lower bound upper boudn https://blockdmask.tistory.com/168 [탐색] lower_bound, upper_bound 안녕하세요. BlockD..
19.11.13 (priority queue, deque)
백준 큐 파트를 풀고있다. 큐 자체가 워낙에 뭐 복잡하지 않고 스택이랑 비슷해서 따로 정리글을 올리지 않겠다. boj1966 풀다가 막혀서 찾아보니 priority queue 라는 우선순위 큐 라는 개념을 사용하더라. 이것은 잘 모르니 정리해보겠다. 빠르게 이어서 우선순위 큐(priority queue)라는 자료구조를 살펴봅시다. 이니셜은 PQ입니다. 이건 큐가 이름 끝에 붙어 있듯이 push, top, pop 연산밖에는 없는데, 하는 일과 내부 구조는 보통 큐와 완전히 다릅니다. top, pop에서 추출되는 원소는 제일 먼저 들어왔던 게 아닌, 현재 우선순위 큐 안에서 제일 우선순위가 높은 원소기 때문!! 가장 유명하고 많이 쓰이는 형태는 클수록 우선순위가 높은 형태, 작을수록 우선순위가 높은 형태입니..
19.11.05 (근황 토크, 팩토리 패턴)
지난 글 작성이 10.20 인걸 보니 정말 오랜기간 비웠구나 싶다. 공부를 하지않은 것은 아니다. 시험기간이 껴있었으니 공부는 당연했다. 사실 4학년 2학기다 보니깐 학과공부가 눈에 들어오지 않는다. 전공이 1개고 나머지가 교양인 이유도 있을터이다. 부재 기간동안에도 boj 는 풀었다. 하지만, 이게 푼 모든 문제를 여기다가 작성을 해야하는지 뭔가 스스로 판단하기가 되게 애매한 것 같다. 쉽게 풀리는 것 또한 올려야 하나 그런 생각이 든다. 애초에 누굴 보여주려는 목적이 아닌 나의 공부를 위한 tistory 인 것인데, 내가 몰라서 헤맨 부분만 올려야 맞지 않나 라는 생각이 든다. 요즘 드는 생각이 많다. 미래에 대한 생각이 대부분이다. 그래서 그 생각을 하지않으려고 회피하려고 하는 내 모습을 자주보게 ..
19.10.20(C++ 스택, string 입력 받기)
프로그래머스에서 dp dfs bfs 부분을 시작하려다 일단 다른 것 기초부터 하자해서 백준 스택 부분에 들어갔다. 굳이 직접 구현 안해주고 C++ 의 STL 을 사용하기로 했다. #include 을 인클루드 해준다. - stack stack 으로 스택을 만들고 - stack.push(데이터)로 추가하고자 하는 데이터를 입력합니다. - stack.size() 는 현재 스택에 저장되어있는 데이터의 갯수를 반환합니다. - stack.top()은 현재 스택 최상위의 데이터를 가져옵니다 (빼내는 것은 아니에요) - stack.pop()은 현재 스택 최상위의 데이터를 제거합니다. - stack.empty() 는 현재 스택이 비었으면 true, 아니면 false를 반환합니다. 출처 : https://m.blog.na..
19.10.19(boj1541)
c++에서 int를 전역변수로 초기화를 안하면 0으로 자동초기화를 해준다는 것을 알았다.(표준에서는 말이다. 0의 초기화가 보장이 안된다는 말도 있으니 따로 초기화 해주는게 나아보인다.) ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ boj 1541 #include int sum, tmp, f, n; char s[55] = { 1 }; int main() { scanf("%s", s + 1); for (int i = 1; s[i - 1]; i++) { if ('0'
19.10.18(char 배열에 대해서)
앞서서 char 배열 널 값 초기화 할 때에 만약 char str[5]="1234"; ( 12345 넣으면 안된다. 널 값이 들어갈 1자리는 비워둬야 된다.) 이렇게 되어있었다고 치자, 여기서 strlen(str) 하면 4가 나올 것이다. str[0]='\0' 하면 str의 첫 부분이 널값으로 취급하여서 모두 다 널 값 초기화가 되는 줄 알았다. 실제로 strlen(str)를 하면 0이 나온다. 그런데 만약 이 부분은 str[0]='5' 로 바꾸면 다시 strlen(str)은 1이 아니라 4가 나오게 될 것이다. 디버깅 해서 보았더니 str[0]='\0'를 하면 모두 널이 되는 것이 아니라 str[0]의 위치만 임시방편으로 널 값이 되어있었다. 이 부분을 풀어주니 str 1,2,3 부분은 다시 각각 "2..
19.10.16 (boj2217, char배열 널 값 초기화)
boj2217 말고도 푼 문제가 몇 있긴한데 boj2217은 문제부터 제대로 이해를 하지 못했다. 나는 당연히 가장 낮은 하중을 가지고 있는 로프의 값보다 높으면 그 로프가 끊어져 들 수 없다고 생각했는데, 만약 10, 15, 40 이라고 쳤을 때에, 나는 당연히 10*3 이라고 생각하였다. 하지만 모든 로프트를 사용할 필요가 없다는 것이다. 10*3의 접근은 맞는데 이 경우엔 30kg 를 들게되고, 40kg 밧줄 하나면 40kg 들게 된다. 15,40 이라 쳤을 때에는 15*2 해서 30kg 이다. 이런 내가 문제 이해를 잘 하지 못하였다... ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ char str[10]; scanf("%s", str); printf(..