반응형 전체 글58 [프로그래머스] 이진탐색 2문제 1. 입국심사나의 풀이function solution(n, times) { var answer = 0; // 구하는 것이 무엇인지 파악하는 것이 중요 여기서는 '시간' // 만약 n = 6, times가 [7,10]이면 // 적어도 1분 이상인 것은 당연, 최대는 확실히 60분 // 60분이 걸렸으면 7분짜리 검사관은 8명, 10분짜리 검사관은 6명을 보내서 // 총 14명을 보냈을 거임. // @만약에 30(round((1+60)/2))분이 걸렸다! 라고하면?? // 7분짜리 검사관은 4명, 10분짜리 검사관은 3명을 보냈음 // 어라? 30분동안 7명 보냈네? // 그럼 정답은 30분보다 작겠네?? // @그럼 15(round((1+30)/2))분이 걸렸다! 라고하면?? //.. 2024. 8. 10. [프로그래머스] 정렬 3문제 1. K번째 수나의 풀이function solution(array, commands) { return commands.map((value2, index2) =>(array.filter((value1, index1)=>(index1 + 1 >= commands[index2][0] && index1 + 1 a-b)[commands[index2][2]-1])}// 커맨드 배열 안에 있는 배열(이하 내부 배열) 1개당 1개의 리턴이 있기 때문에 map// 내부 배열의 0번 인덱스에 있는 값부터 1번 인덱스에 있는 값까지 filter// 정렬 후, 내부 배열의 2번 인덱스에 있는 값 추출다른 풀이function solution(array, commands) { return commands.map(comman.. 2024. 8. 10. [React] useMemo 사용하기 오늘은 useMemo 라는 리액트 훅을 사용해보자. useMemo 리렌더링 사이에서 계산 결과를 저장할 수 있다. useMemo는 컴포넌트 최상단에서 호출한다.1. useMemo의 개념을 간단하게 알아보자.const visibleTodos = useMemo( () => filterTodos(todos, tab), [todos, tab] ); 위 코드는 아주 간단한 사용예다. 매개변수로는 2개의 값을 가진다. 첫번째로는 calculateValue로 저장하려는 값을 계산하는 함수다. 이 함수는 조건이 존재한다.1. 순수함수2. 인자를 받지 않음3. 어떤 타입이든 값을 반환해야 함 리액트는 맨 처음 랜더링 중에 이 함수를 호출한다. 그리고 나서 이후의 렌더링에서는 두번째 인자로 들어가는 의존성 배.. 2024. 8. 10. [React] reducer와 useReducer 사용하기 이번에는 reducer와 useReducer를 공부해보자. 컴포넌트가 복잡해지면 컴포넌트의 state들이 업데이트 되는 것들을 한번에 파악하기 어려울 수 있다. 예를 들어서 어떠한 배열인 state가 있고, 이 state에 요소를 추가하거나 제거하거나 업데이트 하는 세가지의 이벤트 헨들러(이 녀석들은 모두상태 변화 함수를 통해서 state를 변경)가 있다고 한다면 여기저기 흩어져 있는 이벤트 헨들러를 관리하기가 어려울 것이다. 또한 흩어져 있다 보니 코드의 양도 길어질 것이다. 코드의 양을 줄이고 모든 헨들러에 접근하기 쉽게 한곳에 모으기 위해서 reducer라는 단일 함수를 사용한다. 즉, reducer는 state를 관리하는 또 다른 방법인 것이다. 3단계를 거쳐서 state들을 reducer를.. 2024. 8. 9. [React] useEffect 사용하기 useEffect는 리액트에서 컴포넌트의 side effect를 제어하는 리액트 훅이다. 컴포넌트의 side effect는 무엇인가? 리액트에서 컴포넌트의 사이드 이펙트란 컴포넌트가 어떤 동작을 했을때 발생하게 되는 파생적인 효과를 말한다. 예를 들어서컴포넌트의 어떤 값이 변경되었을 때 콘솔레 변경된 값을 출력하거나,컴포넌트가 마운트 되었을 때 콘솔에 Mount라고 출력하거나, 컴포넌트가 리렌더링(업데이트) 되었을 때 콘솔에 Update라고 출력하거나,컴포넌트가 언마운트 되었을 때 콘솔에 Ummount라고 출력하는 상황을 말한다. 이렇게 라이프 사이클을 제어하는 것도 컴포넌트의 사이드 이펙트라고 할 수 있다. 이번에 알아볼 useEffect를 이용하면 이러한 사이드 이펙트들을 제어할 수 있다. 내가 만약.. 2024. 7. 26. [React] React Hooks 리액트 훅스는 클래스 컴포넌트에서만 사용할 수 있는 리액트의 특수한 기능들을 함수 컴포넌트에서도 사용할 수 있도록 도와주는 메소드들을 말한다. 옛날에는 클래스로만 컴포넌트를 만들었다. 그때는 함수 컴포넌트는 UI 랜더링만 되고 리액트 훅스의 모든 기능을 사용할수 없었다. 근데 클래스 컴포넌트는 문법이 너무 더러웠다. 그래서 여러 사람들의 필요에 의해서 함수 컴포넌트에서도 클래스 컴포넌트에서만 사용할 수 있었던 기능들을 사용할 수 있도록 리액트 훅스를 개발했다. 사실 지금까지 useState와 useRef는 리액트 훅이었음. 리액트 훅들은 기능 앞에 접두사로 use가 붙는다. 대략적으로 20개 정도의 훅이 존재한다. 리액트 훅들은 몇가지 조건이 있다.1. 함수 컴포넌트, 커스텀 훅 내부에서만 호출 가능2... 2024. 7. 18. 이전 1 2 3 4 ··· 10 다음 반응형