전체 글

항공대 알고리즘 동아리 Koala 🥰
※ 확장 유클리드 알고리즘은 www.crocus.co.kr/1232 블로그의 도움을 많이 받았습니다. 감사합니다. 1. 추첨상 사수 대작전!(Easy) 풀이 www.acmicpc.net/problem/20410 20410번: 추첨상 사수 대작전! (Easy) 한 줄에 걸쳐 준표가 좋아하는 소수 m, 참가자들이 정한 Seed, 시연으로 공개된 X1, X2 이 주어진다. 항상 가능한 상황만 입력으로 주어진다. www.acmicpc.net 해당 문제에서 M의 범위는 크지 않습니다. 이중 포문을 사용한 브루트 포스를 통해 답을 구할 수 있습니다. #include #include using namespace std; int main() { int m, seed, x1, x2; int a = 0, c = 0, te..
· Codeforce
문제 출처 : codeforces.com/contest/1469 A. Regular Bracket Sequence 문제 정확히 하나의 "(", ")" 과 "?"들로 구성된 길이 n의 문자열 s 가 괄호 문자열인지 아닌지를 판단하는 문제입니다. 풀이 1 먼저 괄호문자열이 되지 않는 case 부터 보자면 첫 번째, 문자열 맨 앞에 ")" 가 오거나, 맨 뒤에 "(" 이 오면, 어떠한 위치에 "?"를 배열 하더라도 괄호문자열이 될 수 없습니다. ex) ")??(?)", "??)(" 두 번째, 문자열의 총 길이가 홀수일 경우, 괄호의 짝이 맞지 않으므로 괄호문자열이 될 수 없습니다. 이 두가지를 제외한 나머지 경우는 문자열 s에 "(", ")" 이 한 쌍만 들어간다는 조건이 있기때문에 "?" 문자를 적절히 잘 ..
· Koala - 1기
* 이 글은 "한국항공대학교 - 알고리즘해석 및 설계" 정렬에 나온 내용을 바탕으로 작성하였습니다. 1. 분할 정복 기법 (Divide - and - Conquer) - 착안점 : 문제의 크기가 커지면 더 풀기가 어렵다. - 주어진 문제를 작은 사례로 나누고(Divide) 각각의 작은 문제들을 해결하여 정복(Conquer)하는 방법 - 순환적(recursive)으로 문제를 푸는 하향식(Top - Down) 접근 방법 - 분할 정복의 설계 전략 (1) 문제 사례를 하나 이상의 작은 사례로 분할(Divide)한다. (2) 작은 사례들을 각각 정복(Conquer)한다. 작은 사례가 충분히 작지 않은 이상 재귀를 사용한다. (3) 필요하다면, 작은 사례에 대한 해답을 통합(Combine)하여 원래 사례의 해답을..
안녕하세요! 항공대학교 알고리즘 학회 Koala 에서 이번 겨울방학에 같이 공부하실 분들을 모집합니다! 저희 학회는 프로그래밍 문제 해결 역량을 중요시 하는 현재 기업 채용 추세에 맞춰 알고리즘 스터디를 교외에서 찾을 필요 없이 우리 학교 학생들과 함께 혼자 접근하기 어려운 알고리즘을 다 같이 공부하자는 취지로 만들어졌습니다! 😀저희 학회는 이런 분들에게 추천합니다! ✔알고리즘에 관심이 있으신 분! ✔코딩 꾸준히 해야한다고 생각하는데 혼자하면 안되는 분! ✔삼성, 카카오, 네이버 등 기업 코딩 테스트에 통과하고 싶은데 정보가 없으신 분! ✔acm-icpc, 삼성 scpc 등 알고리즘 대회에 참가하고 싶은데 정보가 없거나 같이 공부할 사람이 없으신 분! 겨울방학 학회 운영 계획 ✅알고리즘 기초 스터디 언어..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 안녕하세요. 최근 1. 알고리즘 지식보단 구현 2. 삼성 코딩테스트에 대한 글도 있으면 좋겠다 라는 두가지 의견이 있어서 삼성 코딩테스트에서 자주 사용되는 구현 스킬들에 대해서 적어보려고 합니다. 우선 삼성 코딩테스트에 어떤 유형이 나오는지 잘 모르시는 분들을 위해 간략하게 설명드릴게요. 삼성에서는 몇년동안 아래 두 유형만 출제하고 있어요. 1. 시뮬레이션 2. 완전탐색 그중 시뮬레이션은 문제에 나온 내용을 그대로 구현만 하면 되는 문제로, 특별한 알고리즘 지식 없이 문제에 나온대로 구현만 잘 하면 풀 수 있습니다. 그리고 그 구현도 사실 몇가지 틀 안에서 나오니 몇가지 자주 나오는 구현 형태를 익히면 비교적 쉽게 풀 ..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 1학년 - 코딩 문법 이때 익숙해지지 못하면 2학년부터 계속 스노우볼 굴러가니 언어 공부 제대로 합시다. 학점 관리 적당히 3점대 중반이상 해두는게 좋아요. 2학년 - 학점 3점대 중반 이상 관리. 2학년 마친 후 겨울방학에 삼성 상시테스트 A형 취득. 3학년 - 학점관리. 이제 전체 학점 관리도 할 수 있으면 좋지만 그게 힘들고 이미 분야 정했으면 그쪽을 좀더 파고 나머지 학점은 비교적 덜해도 괜찮다고 봐요. 3학년 여름방학, 겨울방학 중 하나는 삼성 상시테스트 A+ 취득에 사용하고 나머지 하나는 인턴이나 프로젝트 경험에 사용. 이 과정으로 졸업하면 학점관리 3점대 중반 이상 되고 상시테스트 A+ 이상 취득에 프로젝트..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 코딩테스트에서 나오는 비주류 유형이 몇가지 있는데, 그중 하나인 정수론에 대해 적어보려고 합니다. 코딩테스트에 자주 나오진 않지만, 보통 많이들 가고싶어하시는 상위티어 기업들에서는 나름 빈출이기도 하니 한번쯤 익혀두시면 좋을것 같습니다! 심지어 코딩테스트에 나오는 수준의 정수론은 대부분 쉬워요. 1. 유클리드 호제법 이건 제가 1학년 2학기 c언어 실습 빨리 끝내고 기다리고 있을 때 교수님께서 한번 코딩해보라고 알려주셔서 그 때 처음 알게된 개념이에요. 1학년도 할 수 있는 알고보면 간단한 내용이니 수식 많다고 포기하지 마시고 한번 읽어보세요! 내용은 간단합니다. a와 b의 최대공약수를 gcd(a, b)라고 표현할게요...
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 문제에 주어진 정보가 많을 경우 구현 시간을 많이 줄일 수 있는 방식이라 코딩테스트, 특히 삼성을 준비하신다면 꼭 알아야 할 방법이라고 생각해서 코딩테스트가 몇개라도 남아있을 때 얼른 올리려고 지금 적습니다. 우선 문제부터 보여드리겠습니다. http://boj.kr/2948 월, 일을 입력받아서 무슨 요일인지 출력하는 문제입니다. 월, 일 순서가 아닌 일, 월 순서로 입력받는다는 함정이 있어요. 이 문제의 해법은 간단한데, 1월 1일이 목요일이니 1월 8, 15, 22, 29일은 모두 목요일입니다. 마찬가지로 1월 2, 9, 16, 23, 30일은 모두 금요일입니다. 그럼 2월 1일은 무슨 요일일까요? 2월 1일은 1월..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 프로그래밍 입문 수업때 질문을 받다보니 아래 두가지 질문만 들어오는걸 보고 이건 답을 알려줘도 실력 향상에 별 도움이 안되겠다 싶어서 글 남깁니다. 1. 답이 안나와요. 2. 답은 나오는데 만점이 안나와요. 1학년만 그런게 아니고 코딩테스트 준비하시는 취준생 분들 가르쳐 드릴때도 똑같았어요. 코딩을 해서 답이 안나오는 경우 아래 세가지는 먼저 생각해보고 정리해서 질문하는게 좋습니다. 1. 어떤 의도로 코드를 작성했는지.(이 부분까지 실행할 때 어떤 결과를 기대했는지) 2. 현재 어떤 결과가 나오는지. 3. 예상되는 원인이 무엇인지(디버깅에 어떤 노력을 했는지) 예를들어 http://boj.kr/1871 문제를 보겠습니다..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 원래 아주 중요한 배열을 이용한 코딩 스킬을 올리려고 했는데, 내용이 너무 길어질것 같기도 하고 그 내용은 코드를 많이 보여드려야 하는데 에타에 적긴 쉽지 않을것 같아서 우선 미뤘습니다. 알아두면 코딩이 훨씬 간단해지니 다음에 방법을 찾아서 적어보도록 할게요! 코딩 테스트, 대회, 취미 등 알고리즘을 공부하는 이유는 여러가지가 있겠지만 처음 공부할 때 어떤 알고리즘부터 해야할지 막막하실거에요. 백트래킹, 동적계획법, DFS, BFS, 그리디 등 검색하면 여러 알고리즘이 나오지만 전 우선 처음 시작했으면 완전탐색부터 잡아야 한다고 생각합니다. 컴퓨터는 1초에 약 1억번의 연산을 합니다. 그리고 대부분의 문제는 시간제한이 ..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 지난번 글을 생각보다 많은 분들이 봐주셔서 xor에 이어 and를 이용한 코딩 스킬을 올릴까 하다가 삼성 코테 볼때 조심할 것들이 더 도움될것 같아서 올립니다. 삼성 코딩테스트 유형(완전탐색, 시뮬레이션)에 대한 내용이 아니라 삼성 코테 환경이나 문제 특성에 대한 글입니다. 삼성 코딩테스트에서 많이들 하는 실수에 대한 내용을 써보려고 합니다. 우선 삼성 코딩테스트 유형을 모르시면 www.swexpertacademy.com의 제일 위의 "신입 SW 역량테스트란?" 들어가서 중간에 "모의검정 문제 예시 풀어보기" 들어가시면 예시 문제 볼 수 있으니 유형은 보고 읽으시는게 좋아요. 언어는 제가 쓰는 c++기준입니다! 1. 전..
이 글은 학회 회원 랑이집사님의 허락을 받아 에브리타임 게시글을 그대로 가져왔습니다. 알아두면 언젠간 쓸데가 있을지도 몰라요 우선 시작하기 전에 xor의 성질 하나만 보고 들어갈게요. 편의상 xor기호는 c언어에서 사용하는 ^ 기호를 사용할건데, 이 글에서 나오는 모든 ^는 제곱의 의미가 아니라 xor입니다! a ^ b ^ c = a ^ c ^ b xor연산은 순서를 바꿔도 같은 결과가 나옵니다. a ^ a = 0 자기자신과 xor연산을 하면 0이 됩니다. a ^ 0 = a 0과 xor하면 자기자신이 나옵니다. 세가지만 기억하시면 돼요 1. temp 없이 두 수 교환하기 보통 두 변수의 값을 교환하는건 아래처럼 사용하죠 temp = a a = b b = temp 하지만 xor의 성질을 이용하면 아래처럼 ..
KauKoala
Koala