문제 문제는 n개의 원소로 이루어진 입력이 주어졌을 때 들어오는 또 다른 input인 query에 대해 n개의 입력 중 두 원소를 더한 sum이 query에 제일 가까운 sum을 구하는 것이다. Competitve Algorithm책에서는 가능한 모든 sum을 보는 O(n2)풀이를 제시하고 있는데, 사실 정렬을 제외한 파트를 O(n)안에 구현하는 방법도 있다. (오버헤드와 사용공간이 좀 늘어나지만) 다음를 보자. 우선, 들어온 n개의 input에 대해 nlgn시간 안에 Sorting을 하자. 그 후 배열의 시작원소를 start, 끝 원소를 end로 두자. 이후 반복문을 돌리는데 각 step에서 input[start]+input[end]를 sum으로 평가한 후 sumquery이면 --end를 하면 sum이..
문제 요약 Input: Test case의 수 T, 이어서 n과 n개의 input이 들어온다. n개의 input을 an이라 할 때 각 ai에서 ai이전 원소들 중 ai보다 작거나 같은 원소들의 개수 합을 i=1~n에 대해 합한 것을 구하세요. 못풀 수가 없지 코드 #include using namespace std; int main() { int T,b_sum,n; int a[1000]; cin >> T; while (T--) { cin >> n; b_sum = 0; for (int i = 0; i > a[i]; for (int i = 1; i < n; i++) for (int j = 0; j < i; j++) if (a[j]
문제 문제 자체는 쉽다 자연수 k가 주어졌을 때 1/k = 1/x + 1/y 를 만족하는 자연수 쌍(x,y)를 찾는 것이다. (대칭 해 제외) Sample Output을 보면 search space에 대해 어느정도 줄일 수 있는 IDEA를 얻을 수 있는데 다음 그림을 보자. 12가 k로 주어졌을 때 y를 보면 k+1부터 2*k까지이다. 사실 생각해보면 x나 y중 하나의 수는 k보다 작거나 같아질 수 없다.(부등식을 생각해보자) 또한 대칭해 제외이니까 2k보다 큰 해는 볼 필요 없다. 따라서 search space의 특성을 반영하여 해를 구하는 프로그램을 짜보면 다음과 같다. //CORRECT SOL #include #include #include using namespace std; int main() ..
문제 Input은 다음과 같은 형식으로 들어온다. 쉬운 문제니까.. 그냥 fop문 하나로 각 case에 대해 search하면 된다. #define _CRT_SECURE_NO_WARNINGS #include #include #include using namespace std; int main() { int T, D, Q; int L[10000]; int H[10000]; int P[10000]; char names[10000][20]; bool come; int idx; scanf("%d", &T); while (T--) { //input part scanf("%d", &D); for (int i = 0; i < D; i++) scanf("%s %d %d", &names[i], &L[i], &H[i]); ..
완전 탐색 algorithm을 무식하게 만들지 않는, 조금이라도 더 빠르게 돌릴 수 있게 하는 몇 가지 팁. 불가능한 탐색 공간의 빠른 가지치기 대칭성 활용 사전 작업, 사전 계산 ~ 공간을 써서 시간을 줄이기 문제를 거꾸로 접근(탐색 주체의 선정) 소스코드의 최적화 빠른 언어: C> C++ > JAVA cin, cout보다는 printf,scanf 힙정렬 보다는 퀵정렬, 힙정렬은 index가 너무 멀리 떨어져있어서 cache의 활용도가 낮다. 2차원 배열에서는 행우선으로 접근 기본 정수 자료형에 대한 비트 연산이 Boolean배열에 대한 bit연산보다 훨씬 빠르다. 가능하면 저차원의 자료구조를 이용하자 거의 모든 자료를 전역으로 두어 한 번만 선언되게 하자 반복/재귀의 갈림길에서는 반복이 낫다. 재귀해..
문제 문제는 요약하면 다음과 같다. 8x8 체스판이 존재할 때 8개의 Queen을 서로 공격할 수 없는 위치에 배치하는 모든 경우의 수를 출력하라. 체스판 채우기 문제다. 완전탐색 문제라서 쉽다고 생각할 수 있지만, Search space를 줄이는게 관건인 테마인 만큼, 쓸데없는 search를 안 하기위해 신경써야한다. ※참고: Queen의 공격 범위는 십자와 대각선상 모든 점 Input: Test case의 개수 TC와 Queen을 반드시 배치해야 하는 (행,렬) 좌표 Output: 양식이 까다로우니 밑의 그림 참고 지금 완전탐색이라는 카테고리를 보고 있는데 이 문제는 그 중에서도 재귀적 퇴각 검색이라는 문제 카테고리에 속한다. 일단 코드부터 보자. 코드는 내가 다 짠 게 아니라 Halim, Steve..
문제 문제는 간단하게. t개의 case가 주어졌을 때 각 case별로 p개의 정수로 된 list가 주어진다. 이 때 list의 부분집합 중 그 합이 n이 되는 경우가 존재하는가? 이 문제를 부분집합 합(subset sum)이라 부르는 경우도 있는데, 기본적으로 all possible subset을 보는 것이 optimal한 문제라고 한다. 이 때 모든 subset을 봐야하는데, 이것을 bit계산으로 매우 빠르게 할 수 있어서 그 방법을 소개한다. #include using namespace std; int main() { int n,t,p, sum,possible; int list[1000];//n> t;//number of test case while (t--) { possible = false;//p..
- Total
- Today
- Yesterday
- gradient descent
- 이산 신호
- 자연어 처리
- Neural Network
- NLP
- 신경망
- 딥러닝
- 영상처리
- CS
- 이미지처리
- 컴퓨터과학
- 컴퓨터 과학
- Logistic Regression
- Andrew ng
- 밑바닥부터 시작하는 딥러닝
- 매트랩 함수
- CNN
- 신호 및 시스템
- 머신 러닝
- 매트랩
- 순환 신경망
- ML
- RGB이미지
- 사진구조
- 영상구조
- 머신러닝
- rnn
- 이미지
- 연속 신호
- 인덱스 이미지
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |