배열 정렬 (array_sort)

이 문서에서는 array_sort 함수에 대해 설명합니다. 이 함수는 배열을 오름차순 또는 내림차순으로 정렬하거나 사용자 정의 함수를 사용하여 정렬 순서를 정의할 수 있습니다.

함수 설명

array_sort 함수는 다음과 같은 인자를 필요로 합니다:

  • 배열: 정렬할 배열을 제공합니다.
  • 정렬 유형 또는 함수:
  • true 또는 false: 오름차순(true) 또는 내림차순(false) 정렬을 나타냅니다.
  • 사용자 정의 함수: 정렬 순서를 정의하는 함수입니다.

이 함수는 제공된 원본 배열의 내용을 수정합니다. 정렬된 복사본을 만들고 싶다면, 먼저 array_copy를 사용하여 배열을 복제한 후 이 함수에 전달해야 합니다.

사용자 정의 함수 사용하기

사용자 정의 함수를 사용할 경우, 이 함수는 두 개의 인자를 받아야 하며, 현재 요소와 다음 요소의 값을 각각 받습니다. 함수는 다음 중 하나의 값을 반환해야 합니다:

  • 0: 두 요소가 같을 경우
  • <= -1 (음수): 첫 번째 요소가 두 번째 요소보다 앞설 경우
  • >= 1 (양수): 첫 번째 요소가 두 번째 요소보다 뒤에 올 경우

사용자 정의 함수가 반환하는 값은 정수여야 하며, 1보다 작은 부동 소수점 값은 0으로 읽힙니다. 따라서 부동 소수점 값을 사용하는 경우 sign() 또는 round()를 사용해야 합니다.

사용자 정의 함수가 두 요소에 대해 0을 반환하면(또는 오름차순/내림차순 정렬에서 두 요소가 같을 경우), 정렬 알고리즘(qsort)은 안정적이지 않기 때문에 그 쌍의 순서가 보존되지 않을 수 있습니다.

문자열 배열이 포함된 경우, 기본 오름차순/내림차순 정렬을 사용할 때 문자열은 영어 알파벳 순으로 정렬됩니다. 다른 데이터 유형은 그 자체의 숫자 값에 따라 정렬됩니다.

문법

array_sort(variable, sorttype_or_function);

인자 설명

인자 타입 설명
variable Array 정렬할 배열을 담고 있는 변수
sorttype_or_function Boolean 또는 Script Function/Method 정렬 유형 (오름차순은 true, 내림차순은 false) 또는 정렬에 사용할 함수 참조

예제

기본 예제

var _a = [10, 9, 8, 7, 6, 5];
array_sort(_a, function(elm1, elm2) {
    return elm1 - elm2;
});

위 코드는 사용자 정의 정렬 함수를 사용하여 배열을 오름차순으로 정렬합니다. 정렬 함수는 두 배열 요소를 elm1elm2로 받아서 이들 간의 차이를 계산합니다. elm1elm2보다 크면 양수 결과가 나와 elm1elm2 뒤에 오게 되어 오름차순으로 정렬됩니다.

확장된 예제

var _xx, _yy, _a;
for (var i = 0; i < 10; i++) {
    _xx = irandom(room_width);
    _yy = irandom(room_height);
    _a[i] = instance_create_layer(_xx, _yy, layer, obj_Bullet);
}
show_debug_message(_a);

var _f = function(inst1, inst2) {
    return inst1.x - inst2.x;
};
array_sort(_a, _f);
show_debug_message(_a);

위 코드는 방 안에 무작위 위치에 배치된 10개의 인스턴스 배열을 생성합니다. 디버그 메시지는 다음과 같은 결과를 보여줄 것입니다:

[ 100011, 100004, 100009, 100006, 100012, 100008, 100010, 100005, 100007, 100003 ]

그 후, array_sort 함수에서 사용할 메서드를 생성하여 방 안의 인스턴스 X 위치 간의 차이를 반환합니다. 그런 다음 array_sort 함수를 실행하여 인스턴스를 X 값에 따라 낮은 것부터 높은 것 순으로 정렬합니다. 배열의 출력 결과는 다음과 같을 것입니다:

[ 100003, 100004, 100005, 100006, 100007, 100008, 100009, 100010, 100011, 100012 ]

활용 예제

  1. 정수 배열 정렬: gml var numbers = [5, 3, 8, 1, 2]; array_sort(numbers, true);
  2. 문자열 배열 정렬: gml var names = ["Charlie", "Alice", "Bob"]; array_sort(names, true);
  3. 사용자 정의 객체 정렬: gml var objects = [obj1, obj2, obj3]; array_sort(objects, function(o1, o2) { return o1.health - o2.health; });
  4. 내림차순 정렬: gml var scores = [100, 200, 150]; array_sort(scores, false);
  5. 복잡한 사용자 정의 정렬: gml var items = [item1, item2, item3]; array_sort(items, function(i1, i2) { || |---| });

Read more

기술 문서 해설 및 활용 예제

이 문서는 특정 기술에 대한 설명과 활용 방법을 다룹니다. 아래에서 내용을 쉽게 이해할 수 있도록 해설하고, 다양한 활용 및 응용 예제를 추가로 제공합니다. 기술 개요 이 기술은 게임 개발에서 자주 사용되는 기능으로, 특정 작업을 자동화하거나 효율적으로 처리하는 데 도움을 줍니다. 주로 게임의 로직을 구성하거나 사용자 인터페이스를 제어하는 데 사용됩니다. 주요

By 이재협/실장/시스템개발실/PHYSIA

키워드 설명서

이 문서는 특정 키워드에 대한 설명과 사용법을 제공합니다. 문법 (arguments); 인수 인수 이름 유형 설명 argument_name 인수에 대한 설명을 여기에 작성합니다. 반환값 (선택적 설명) 예제 code_example() { // 여기에 코드 예제를 설명합니다. } 코드 예제 설명 위의 코드 예제는 특정 기능을 수행하는 함수의 기본 구조를 보여줍니다. 이 함수는 인수를 받아들이고, 특정

By 이재협/실장/시스템개발실/PHYSIA

GameMaker 환경 설정 및 기능

이 문서에서는 GameMaker의 환경 설정 및 다양한 IDE 기능에 대한 정보를 제공합니다. 다음은 주요 항목들입니다: IDE 환경 설정 IDE(통합 개발 환경) 설정은 GameMaker의 전반적인 사용 경험을 조정하는 데 도움을 줍니다. 여기서 사용자는 개인의 필요에 맞게 다양한 옵션을 설정할 수 있습니다. 주요 설정 항목 설정 항목 설명 테마 IDE의 색상

By 이재협/실장/시스템개발실/PHYSIA

GameMaker IDE 설명서

GameMaker IDE는 게임을 만들고 소프트웨어에서 제공하는 모든 기능을 활용하는 주요 인터페이스입니다. 이 프로그램은 시작 화면부터 게임을 만들기 위해 사용하는 모든 편집기 창까지 포함되며, 매뉴얼과 다양한 튜토리얼에서 IDE라고 언급됩니다. IDE의 구성 요소 다음 섹션에서는 IDE에 대한 정보를 다룹니다: 1. 설정 및 기능 IDE의 설정 및 기능은 사용자가 게임 개발을 보다 효율적으로

By 이재협/실장/시스템개발실/PHYSIA