Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 풀이
- lob
- 자료구조 복습
- Python
- Javascript
- c
- Sookmyung Information Security Study
- BOJ
- 기계학습
- SWEA
- 파이썬
- hackctf
- XSS Game
- 드림핵
- 백준
- BOJ Python
- CSS
- siss
- WarGame
- 웹페이지 만들기
- c++
- 생활코딩
- 숙명여자대학교 정보보안동아리
- C언어
- 머신러닝
- 숙명여자대학교 정보보안 동아리
- hackerrank
- The Loard of BOF
- PHP 웹페이지 만들기
- HTML
Archives
- Today
- Total
혜랑's STORY
[HackerRank] Correctness and the Loop Invariant 본문
2021 SISS 21기 활동/2학기 C
[HackerRank] Correctness and the Loop Invariant
hyerang0125 2021. 10. 6. 11:495주차 자유 문제
Prepare > Algorithms > Sorting
풀이
삽입 정렬 코드를 완성하는 문제이다. 삽입 정렬의 기본 알고리즘은 다음과 같다.
1. 리스트의 인덱스 0번 위치의 항목 한 개는 이미 정렬이 완료된 리스트로 취급한다.
2. 정렬 리스트의 오른쪽에 있는 정렬되지 않은 원소(1번 위치의 원소)는 자신의 앞에 있는 원소와 크기를 비교하여 앞쪽 원소가 더 크면 자리를 바꾼다.
3. 동일하게 2번 위치에 있는 원소도 왼쪽으로 전진하면서 자기 자리를 찾을 때까지 왼쪽으로 전진한다.
4. 이 과정을 더 이상 비교 대상 원소가 없을 때까지 반복한다.
위 알고리즘을 바탕으로 코드를 작성해 보았다.
int main() {
int n, temp, i, j;
vector<int> arr;
cin >> n;
for(i=0; i<n; i++){
cin >> temp;
arr.push_back(temp);
}
//insertion sort
for(i=1; i<arr.size(); i++){
temp = arr[i];
for(j=i-1; j>=0 && temp < arr[j]; j--)
arr[j+1] = arr[j];
arr[j+1] = temp;
}
for(i=0; i<arr.size(); i++){
cout << arr[i] << " ";
}
return 0;
}
실행 결과는 다음과 같다.
'2021 SISS 21기 활동 > 2학기 C' 카테고리의 다른 글
[HackerRank] Strong Password (0) | 2021.11.08 |
---|---|
[HackerRank] The Full Counting Sort (0) | 2021.10.06 |
[HackerRank] Combo Meal (0) | 2021.10.01 |
[HackerRank] Electronics Shop (0) | 2021.10.01 |
[HackerRank] Closet Numbers (0) | 2021.09.24 |