목록2024/11 (8)
마이라이프해피라이프
✅ 문제https://www.acmicpc.net/problem/2805✅ 이진 탐색이진 탐색 문제의 특징이진 탐색 문제는 대부분 데이터가 굉장히 많아서, 탐색에 시간이 굉장히 오래걸릴 거 같은 느낌이 드는 문제이다.이 문제 역시도 데이터(나무의 높이)가 최대 1000000000 일 수 있어, 1씩 높여가면서 탐색을 하려고 할 때 시간 초과가 날 거라는 건 쉽게 짐작할 수 있다.참고로 이 자료를 저장할 수 있을 만한 자료형에 적절히 저장해야 한다. (long long 등)이진 탐색 문제를 풀려면?이진 탐색 문제에서는 정렬을 하거나, 최대 최소 값을 아는 것이 중요하다.중간값을 적절히 찾아야하고, start지점과 end지점을 적절히 업데이트 해야 한다.종료 조건도 중요하다. 언제까지 이 탐색을 계속할 것인..
문제https://www.acmicpc.net/problem/24444BFS와 DFS?그래프 탐색 알고리즘으로는 흔히 아는 BFS와 DFS가 있다.BFS는 너비 우선 탐색이고, DFS는 깊이 우선 탐색이다.1번과 연결된 노드가 2, 3이고 2와 연결된 노드가 4이라고 가정해 보자. BFS로 탐색하면 1 -> 2 -> 3 -> 4의 경로로 탐색할 것이다. DFS로 탐색하면 1 -> 2 -> 3 -> 4의 경로로 탐색할 것이다. (오름차순으로 방문한다고 가정했을 때) BFS는 같은 깊이의 노드를 모두 탐색하고 난 다음에 더 깊은 노드로 들어간다. DFS는 연결된 가장 깊은 노드로 먼저 이동한다.BFS는 어떻게 구현되는가?BFS는 주로 deque로 구현한다. 왜냐하면, deque는 push_back(), po..
1620 - 나는야 포켓몬 마스터 이다솜https://www.acmicpc.net/problem/1620새롭게 알게된 자료형 - unordered_map특징- 해시 기반으로 검색하는 자로형 (검색이 빠름 O(1)의 복잡도)- 삽입된 순서를 기억하지 않음- 메모리 사용량 많음- 자체적으로 정렬할 수 없음. 정렬하고 싶을 때는 vector 등의 자료형으로 변환한 후에 정렬해야 함. std::vector> sortingArray(entryRecord.begin(), entryRecord.end()); std::sort(sortingArray.begin(), sortingArray.end(), [](std::pair& a, std::pair& b) { retu..
오늘은 동아리 1차 행사에 다녀왔다.서버 파트로 참여해서 그동안 서버파트의 사람들만 만나왔었는데, 1차 행사에서는 디자인, 기획, Ios, 웹 개발자까지 다양한 사람을 만날 수 있었다. 1차 행사는 노는 행사였다. 노는 동안 나의 기분은 별로 좋지 않았다. 약간의 현타가 왔다. 이제 졸업할 때가 다 됐는데, 남들은 이렇게 치열하게 살아가는데 시간을 버려도 되나? 같은 걱정 때문이었다. 놀 줄 아는 사람이 잘 논다고,, 난 놀 줄 모르는 사람인가 보다.. 논다는 것 하나에 이렇게 죄책감이 들다니 말이다. 그냥 소소한 일상이었지만, 블챌 참여하기 위해 남겨본다. 이렇게 작고 소중한 일상을 기록하는 것도 답답함을 해소하는 데 도움이 되는 것 같다. 앞으로도 종종 글을 남겨야겠다. 그럼 다들 행복한 하루 보..
💻 문제 - 25206 번 수학, 구현, 문자열https://www.acmicpc.net/problem/25206✅ 관련 이론pair 자료형std::pair는 두 개의 이기종 객체를 단일 단위로 저장하는 방법을 제공하는 클래스 템플릿이다. 사용 예시는 다음과 같다.접근할 때는 요소.first, 요소.second로 접근한다. vector> gradeTable = {{"A+", 4.5}, {"A0", 4.0}, {"B+", 3.5}, {"B0", 3.0}, {"C+", 2.5}, {"C0", 2.0}, {"D+", 1.5}, {"D0", 1.0}};if (entry.first == grade) {tempGrade = entry.second;}언제 pair 자료형을 사용하면 좋을까? (고민해야 할 부분)p..
나는 창업을 하고 싶은 걸까? 창업은 어떤 사람이 하는 걸까? 창업을 해도 되는 걸까? 어떤 사람들이 성공하는 걸까? 이런 고민들을 하게 되는데, 사실 답이 없는 질문들 같다. 나를 망설이게 하는 이런 질문에서 벗어나고자 창업에 더 가까이 다가가보기로 했다. 아래 글에선 데모데이 행사에서 느꼈던 점들을 짧게 작성해보려고 한다. 데모데이 시작에 앞서 셀트리온의 회장님이 줌에서 창업에 대한 조언을 해주셨다. 새로운 도전과 모험을 하는 젊은이가 있는 나라가 되어야한다는 취지의 말을 해주셨다. 창업을 하는 것이 나라를 위한 일이라고 생각한 적 없는데, 창업을 하게 된다면 이런 자부심도 나를 살아가게 하는 말들 중 하나가 되지 않을까 생각했다. 또한, 창업가가 하면 안 되는 것들에 대해서도 말해주셨다. 중도포..
💻 문제 - 2480 번 조건문https://www.acmicpc.net/problem/2480✅ 관련 이론vector 자료형vector::iterator type으로 요소에 접근한다.vector.begin(), vector.end()로 처음과 끝의 포인터를 확인한다.원하는 index의 값을 얻으려면 vector.begin() - iter로 접근한다. vector.at(index)로 원하는 index에 접근한다. (index 범위가 유효하지 않을 때 out_of_range 오류가 발생한다.)reverse로 접근하고 싶을 때는 vector::reverse_iterator로 접근한다.vector.rbegin(), vector.rend()로 처음과 끝의 포인터를 확인한다.이때, 접근하는 iterator는 처..
💻 문제 - 11382 번 입출력https://www.acmicpc.net/problem/11382 ✅ 관련 이론int 자료형 크기short: 2 bytes 이상int: 2 bytes 이상long: 4 bytes 이상long long: 8 bytes 이상(자료형 크기는 운영체제에 따라 다르기 때문에 sizeof를 통해 확인해야 한다.)signed와 unsignedsigned는 음수, 양수를 저장할 수 있는 타입이다. (ex. 1 bytes면 -128~127 저장)unsigned는 양수만 저장할 수 있는 타입이다. (ex.1 bytes면 0~255저장)문제에 적용한 이론문제에서 필요한 a,b,c는 1~10^12의 값을 가질 수 있음.(최대 13자리)각각의 변수는 최소 8 bytes를 저장할 수 있어야 함..