250926 알고리즘

2025. 9. 26. 13:11·📖TIL

문제를 해결하기 위한 과정을 논리적 절차에 따라 구성한 일련의 단계

문제 이해 → 예시와 테스트 케이스 작성 → 알고리즘 설계 → 알고리즘 구현 및 검증 → 알고리즘 분석과 개선

 

Fisher Yates Shuffle

/// <summary>
/// 카드 섞어주는 기능
/// </summary>
/// <param name="inputArr"> 섞이지 않은 카드배열 </param>
public static void FisherYatesShuffle(int[] inputArr)
{
    Random rnd = new Random(); // 섞을거니 랜덤을 만듦

    for ( int i = inputArr.Length - 1; i > 0; i-- ) // 인덱스 역순
    {
        int j = rnd.Next(0, i + 1); // 0부터 i까지 랜덤 인덱스 선택 (+1 이유는 0 이상 i 미만이기 때문)

        int temp = inputArr[i];
        inputArr[i] = inputArr[j];
        inputArr[j] = temp;
    }
}
static void Main(string[] args)
{
    int[] num = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

    FisherYatesShuffle(num);

    foreach ( var a in num )
    {
        Console.Write(a);
    }
}
// 배열을 반복하면서, 인접한 두 값을 비교
// 두 값이 크기 순서에 맞지 않으면 위치를 교환
// 배열 끝까지 비교를 반복하면 가장 큰 값이 배열 끝으로 이동
// 배열이 정렬될 때까지 위 과정을 반복

public static void BubbleSort(int[] Array)
{
    for( int i = 0; i < Array.Length - 1; i++ ) // 일단 0부터 모든 요소 돌 예정
    {
        for ( int j = 0; i < Array.Length - i - 1; j++ )
        {
            if (Array[j] == Array[j+1] ) // 잘못된 순서라면?
            {
                // 스왑 실행
                int temp = Array[j];
                Array[j] = Array[j + 1];
                Array[j + 1] = temp;
            }
        }
    }
}

https://www.youtube.com/watch?v=Iv3vgjM8Pv4

// 선택 정렬
// 매 단계마다 배열에서 가장 작은걸 찾아서 배열 맨 앞에 가져다 두는 방식
// 비교횟수가 여전히 많긴 하지만, 버블 정렬보다는 낫다

public static void SelectionSort(int[] array)
{
    for (int i = 0; i < array.Length - 1; i++ )
    {
        int minIndex = i; // 하나를 선택하여 기준

        for(int j = i +1; j < array.Length; j++ )
        {
            if (array[j] < array[minIndex]) // 반복문을 돌며 선택한 j 와 비교
            {
                minIndex = j; // 반복을 돌다가 필요할 경우 최소값을 j로 바꾼다
            }
        }
        //여기까지 왔다는 뜻은, 배열 끝까지 다 봤다는 의미

        int temp = array[i];
        array[i] = array[minIndex];
        array[minIndex] = temp;
    }
}

https://www.youtube.com/watch?v=hFhf9djnM5A

 

Stopwatch watch = new Stopwatch();

watch.Start(); // 스탑워치 On

SelectionSort(ints);

Console.WriteLine(watch.ElapsedMilliseconds + "여기있음");
watch.Stop(); // 스탑워치 Off

// Sleep 은 진짜 모든게 그 시간만큼 멈춤
// StopWatch는 시간은 시간대로 흐르고, 필요할 경우 3초 후에 수행 등등
Stopwatch watch = new Stopwatch();

Console.CursorVisible = false;

watch.Start(); // 스탑워치 On

while (true)
{
    Console.WriteLine(watch.ElapsedMilliseconds / 1000);
    Console.SetCursorPosition(0, 0);
}

// Sleep 은 진짜 모든게 그 시간만큼 멈춤
// StopWatch는 시간은 시간대로 흐르고, 필요할 경우 3초 후에 수행 등등

 

'📖TIL' 카테고리의 다른 글

250929 Revision  (0) 2025.09.29
250926  (0) 2025.09.26
250926 Revision  (0) 2025.09.26
250925  (0) 2025.09.25
250925 Revision  (0) 2025.09.25
'📖TIL' 카테고리의 다른 글
  • 250929 Revision
  • 250926
  • 250926 Revision
  • 250925
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    til
    GitHub
    메모리관리
    게임기획
    OOP
    unity
    객체지향
    csharp
    자료형
    CodingTest
    자료구조
    디자인패턴
    기획
    문법
    유니티
    algorithm
    c#
    게임디자인
    부트캠프
    gamedesign
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
250926 알고리즘
상단으로

티스토리툴바