본문 바로가기

분류 전체보기59

소프티어 역량 진단 취득 후기 (HSAT - Level 3) HSAT(소프티어 역량 진단)은 현대자동차그룹에서 실시하는 코딩역량인증 평가이다. Level 3를 취득하면 현대자동차, 기아, 현대모비스, 현대오토에버, 현대차증권, 현대엔지비 SW 분야 지원 시, 코딩테스트 면제를 해준다. 3시간 동안 두 문제를 모두 맞아야 통과가 되고, 하나라도 틀리면 불합격이다 (너무 빡쎈거 아닌가;;) 8월 11일 금요일에 오후 5시 ~ 오후8시에 시험이 실시되었고, 시험 문제는 결과 발표 당일 소프티어 홈페이지에 올라왔다. 기출문제를 봤는데 너무 어려워서 한 번에 따기 힘들 것 같았지만, 생각보다 문제들이 기출문제처럼 어렵게 나오지 않아서 운 좋게 한 번에 통과했다. 오예! 2023. 8. 26.
함수형 인터페이스(Functional Interface) 함수형 인터페이스(Functional Interface) : 단 하나의 추상 메서드만 선언된 인터페이스 @FunctionalInterface interface SquareFunction() { public abstract int square(int a); } * interface의 추상메서드는 public하면서 abstract이므로 public abstract 생략 가능 * @FunctionalInterface 어노테이션은 안붙여도 상관없지만 붙이면 함수형 인터페이스 사용시 컴파일러가 두 개 이상의 추상 메서드를 만드는 것을 막아줌 함수형 인터페이스를 사용하면 람다식을 참조변수에 담아 사용할 수 있다. (단, 함수형 인터페이스의 메서드와 람다식의 매개변수 개수와 반환타입이 일치해야 한다) @Functio.. 2023. 7. 16.
람다식(Lambda Expression) 람다식(Lambda Expression) : 함수(메서드)를 간단한 식(expression)으로 표현하는 방법 함수 vs 메서드 근본적으로는 같지만, 함수는 클래스에 독립적이고 메서드는 클래스에 종속적이다. (클래스 밖에 메서드를 정의할 수 없다) 함수는 일반적인 용어이고 메서드는 객체지향개념 용어이다. 메서드를 람다식으로 바꾸는 방법 int square(int a) { return a * a; } 1. 반환타입과 메서드이름을 지운다. (int a) { return a * a; } 2. 매개변수 오른쪽에 화살표( → )를 추가한다 (int a) -> { return a * a; } 3. 반환값이 있는 경우, 식이나 값만 적고 return문 생략가능하다. (세미콜론도 생략가능) (int a) -> { a .. 2023. 7. 15.
재귀함수 사용 시 코드 실행시간을 단축하는 방법 (C++) 재귀 문제를 풀면서 분명 같은 로직인데 실행시간이 많게는 10배이상 차이나는 것을 보았다. https://www.acmicpc.net/problem/14889 14889번: 스타트와 링크 예제 2의 경우에 (1, 3, 6), (2, 4, 5)로 팀을 나누면 되고, 예제 3의 경우에는 (1, 2, 4, 5), (3, 6, 7, 8)로 팀을 나누면 된다. www.acmicpc.net 14889번 문제는 N제한이 20이하이므로 순열을 사용하여 스타트팀과 링크팀으로 나눈다면 시간복잡도가 최대 20! = 2,432,902,008,176,640,000 이 되어버리기 때문에 재귀(백트래킹)를 사용하여 풀어야한다. void solve(vector a, vector b, int idx) { if (idx == n + 1.. 2023. 7. 14.
이펙티브 자바 아이템29까지 읽고 느낀점 이펙티브 자바를읽으려고 마음먹었던 가장 큰 계기는 개발바닥 유튜브에서 진행했던 '랠릿 이력서 리뷰'를 보면서 나의 공부 방향이 잘못되었음을 느꼈고 기초부터 다시 공부해야겠다는 생각이 들어서이다. 각종 백엔드 개발자 공고를 보면 MSA, kafka, 등등 이름만 들어도 무시무시한 기술들을 우대사항으로 넣고 CQRS, 퍼사드 등등 여러 고급패턴의 존재를 보며 이걸 어디서부터 공부해야하지 라는 생각이 들었다. 하지만, 이러한 생각의 방향이 잘못되었다는 것은 이펙티브 자바를 보면서 깨달았다. 다양한 디자인 패턴(싱글톤, 정적 팩토리), 자바 제네릭, 컬렉션 등 자바의 기초적인 내용도 제대로 알고 있지 못하면서 위의 고급 기술들을 배워보겠다고 나댔던 내가 부끄러워졌다. 앞으론, 싸피 과정과는 별개로 자바 기초를 .. 2023. 7. 10.
백준 + 프로그래머스 + SWEA 자동 커밋 익스텐션 백준허브 설치 https://chrome.google.com/webstore/detail/%EB%B0%B1%EC%A4%80%ED%97%88%EB%B8%8Cbaekjoonhub/ccammcjdkpgjmcpijpahlehmapgmphmk?hl=ko 백준허브(BaekjoonHub) Automatically integrate your BOJ submissions to GitHub chrome.google.com 사용법 https://github.com/BaekjoonHub/BaekjoonHub GitHub - BaekjoonHub/BaekjoonHub: 백준 자동 푸시 익스텐션(Auto Git Push for BOJ) 백준 자동 푸시 익스텐션(Auto Git Push for BOJ). Contribute to .. 2023. 7. 6.