오늘 배운 것
- git CLI 로 원격 레포에 commit & push 하는 방법
git init # 현재 파일과 git 연동
git add . # 현재 변경사항 스테이징
git commit -m "commit message" # 윈도우의 경우 커밋 메시지를 꼭 쌍따옴표로 감싸야 에러가 안난다.
#OR
git commit -am "commit message" # add 과정과 message 작성 과정을 동시에 진행할 수 있다.
git push # 현재 커밋 내용 push
- localeCompare 메서드
a 와 b가 있을 때, a.localeCompare(b) 를 실행하면, a < b 라면 -1, a > b 라면 1, a === b 라면 0을 리턴한다.
이 메서드를 sort 메서드에 compareFunction으로 전달하여 사용하면 유용하다.
// 각 문자열 a와 b의 n번째 문자를 기준으로 비교하여 정렬
// localeCompare 함수 사용 x, if 문으로 직접 비교
let answer = strings.sort((a, b) => {
if (a[n] < b[n]) return -1;
if (a[n] > b[n]) return 1;
if (a[n] === b[n]) {
if (a < b) return -1;
else return 1;
}
});
- 위 if...else 문으로 작성된 코드를 localeCompare 을 사용하여 작성하면 아래와 같다.
let answer = strings.sort((a, b) => {
// a[n]과 b[n]이 같은 경우(예외) 문자열을 기준으로 정렬
if (a[n] === b[n]) return a.localeCompare(b);
// 그 이외의 경우 a[n]과 b[n]을 비교하여 리턴
else return a[n].localeCompare(b[n]);
});
return answer;
- 삼항 연산자로 더 짧게 표현하면 아래와 같다. (개인적으로는 가독성이 좋지 못한 것 같다... 처음 코드를 보고 이해하기가 쉽지 않았다. 메서드를 몰랐어서 그런가? 일단 sort 메서드 자체가 엄청 헷갈림.)
function solution(strings, n) {
return strings.sort((a, b) => (a[n] === b[n] ? a.localeCompare(b) : a[n].localeCompare(b[n])));
}
추가로 공부할 것
- CLI 환경에서 git PR 요청 하는 법 : 일단 해봐야지
- 나동빈님의 책을 보고 알고리즘 개념을 훑으면서(?) 공부하게 되었다.
오늘의 느낀 점
- 처음으로 오프라인 스터디를 해봤는데, 매일 온라인으로만 개발 하시는 분들을 만나다가 실제 사람을 만나니까(?) 내가 개발을 공부하고 있다는게 피부로 와닿았다. 진짜 장난 아니고 열심히 해야겠다.
- 어제 라이브 세션 시간에 엔지니어님이 러닝 커브를 빨리 그려서 빨리빨리 치고 나가는 것도 중요하다는 말씀을 해주셨다. 지금 하고 있는 알고리즘 문제풀이 단계가 솔직히 그렇게 높진 않은데 여기서 관련 개념을 더 공부해서 러닝커브를 더 가파르게 상승시켜야겠다.
- 다만 절대 건강에 무리는 없게 해야지... 어제 늦게 자서 오늘 수영을 안갔다. ㅠ
'이전 기록' 카테고리의 다른 글
[TIL] 2022-0523 (0) | 2022.05.24 |
---|---|
[TIL]2022-0203 (THU) (0) | 2022.02.04 |
[TIL]2022-0120 (THU) (0) | 2022.01.20 |
[TIL]2022-0118 (TUE) (0) | 2022.01.18 |
[TIL]2022-0116 (SUN) (0) | 2022.01.16 |