배열 비교하기
https://school.programmers.co.kr/learn/courses/30/lessons/181856
두 배열을 비교하여 인덱스 갯수가 다르거나, 인덱스 갯수가 같을 때 각각 배열의 합을 구해서 비교하고 조건에 맞는 값을 반환하는 문제이다.
내가 작성한 풀이는 이렇다.
if 문으로 비교하고, for 문으로 각각 배열의 합을 구해 비교하는 방식을 사용했다.
using System;
public class Solution
{
public int solution(int[] arr1, int[] arr2)
{
int answer = 0;
int sum1 = 0;
int sum2 = 0;
if(arr1.Length < arr2.Length) answer = -1;
else if(arr1.Length > arr2.Length) answer = 1;
else if(arr1.Length == arr2.Length)
{
for(int i = 0; i < arr1.Length; i++)
{
sum1 += arr1[i];
sum2 += arr2[i];
}
if(sum1 > sum2) answer = 1;
else if(sum1 < sum2) answer = -1;
else answer = 0;
}
return answer;
}
}
각 케이스가 명확하게 1 , -1 , 0 을 반환
읽는 사람이 로직을 바로 이해할 수 있음
정확하지만 간결하지는 않다.
두 숫자를 비교하는 내장 메서드
arr1.Length 와 arr.Length 를 비교하고 sum1 과 sum2 를 비교
결국 두 숫자를 비교해서 크면 1 , 작으면 -1 , 같으면 0 을 반환하는 패턴이다.
C# 에서는 이걸 한 번에 해주는 내장 메서드가 있는데 바로 CompareTo 이다.
using System;
public class Solution
{
public int solution(int[] arr1, int[] arr2)
{
if (arr1.Length != arr2.Length)
return arr1.Length.CompareTo(arr2.Length);
int sum1 = 0, sum2 = 0;
for (int i = 0; i < arr1.Length; i++)
{
sum1 += arr1[i];
sum2 += arr2[i];
}
return sum1.CompareTo(sum2);
}
}
그런데 CompareTo 가 반드시 1 , -1 만 반환한다는 보장은 없다. 구현에 따라 다른 양수나 음수가 나올수 있기 때문이다.
이 문제에서는 통과되지만 엄밀히는 원래 코드처럼 명시적으로 1 , -1 , 0 을 반환하는 게 더 안전하다.
CompareTo
C# 에서 두 값을 비교해서 정렬 순서를 판단할 때 사용하는 메서드이다.
▼ 문법
a.CompareTo(b)
▼ 결과
| 결과 | 의미 |
| 음수 | a 가 b 보다 작다 |
| 0 | a 와 b 가 같다 |
| 양수 | a 가 b 보다 크다 |
문자열 비교도 가능
string a = "apple";
string b = "banana";
Console.WriteLine(a.CompareTo(b)); // 음수
정렬에서 사용
List<int> numbers = new List<int> { 5, 2, 8, 1 };
numbers.Sort((a, b) => a.CompareTo(b));
Console.WriteLine(string.Join(", ", numbers));
▲ 코드 풀이
List<int> numbers = new List<int> { 5, 2, 8, 1 };
- int 타입의 리스트를 만들고 5 , 2 , 8 , 1 로 초기화
numbers.Sort((a, b) => a.CompareTo(b));
리스트를 정렬하는데 , (a, b) => a.CompareTo(b) 는 람다식으로 정렬 기준을 지정한다.
- a.CompareTo(b) 가 음수이면 a 가 앞으로
- 양수이면 b 가 앞으로
- 결과적으로 오름차순으로 정렬
Console.WriteLine(string.Join(", ", numbers));
리스트 요소들을 " , " 로 이어붙여서 출력
결과 : 1, 2, 5, 8
참고로 int 리스트 오름차순 정렬은 그냥 numbers.Sort() 만 사용해도 동일한 결과가 나온다.
CompareTo 를 사용하는 것은 내림차순이나 커스텀 정렬을 할 때 더 유용하다
'📖TIL > ✅CodingTest' 카테고리의 다른 글
| 문자열 순회하며 교체하기 (0) | 2026.06.03 |
|---|---|
| 옷가게 할인 받기 (0) | 2026.06.01 |
| 문자 리스트를 문자열로 변환 (0) | 2026.05.29 |
| 숨어있는 숫자의 덧셈 (0) | 2026.05.16 |
| 문자열 패딩 ( Padding ) (0) | 2026.05.14 |