8월, 2019의 게시물 표시

[프로그래머스] 다리를 지나는 트럭 javascript

[스택/큐] level2 다리를 지나는 트럭 javascript 조건 1. 트럭은 1초에 1만큼 움직이며, 다리 길이는 bridge_length이고 다리는 무게 weight까지 견딥니다. 2. 트럭이 다리에 완전히 오르지 않은 경우, 이 트럭의 무게는 고려하지 않습니다. 제한사항 bridge_length는 1 이상 10,000 이하입니다. weight는 1 이상 10,000 이하입니다. truck_weights의 길이는 1 이상 10,000 이하입니다. 모든 트럭의 무게는 1 이상 weight 이하입니다. 입출력 예 경과 시간 다리를 지난 트럭 다리를 건너는 트럭 대기 트럭 0 [] [] [7,4,5,6] 1~2 [] [7] [4,5,6] 3 [7] [4] [5,6] 4 [7] [4,5] [6] 5 [7,4] [5] [6] 6~7 [7,4,5] [6] [] 8 [7,4,5,6] [] [] 코드 /** * @param bridge_length 다리 길이 * @param weight 다리가 버티는 무게(하중) * @param truck_weights 다리를 건널 트럭들의 배열(value:트럭무게) **/ function solution(bridge_length, weight, truck_weights) { let time = 0, //다리를 건너는 시간을 담는 변수 cross_trucks=[], //다리를 건너는 중인 트럭들의 배열({time,weight}, ...) copy_trucks = truck_weights.concat(), //truck_weights의 copy하여 대기트럭 배열로 사용(다리 진입 시 배열에서 제거) bridge_weight = 0; //현재 다리를 건너는 트럭 무게의 총 합(이 변수는 weight값보다 작거나 같아야한다) //경과시간을 나타내는 loop(대기 중인 트럭이 있거나 다리를 건너는 트럭

[프로그래머스] 기능개발 javascript

[스택/큐] level2 기능개발 javascript 조건 1. 첫 번째 작업이 완료 되어야 배포가 이루어 짐. 2. 그 이전에 완료된 작업의 경우 첫 번째 작업이 완료 될때까지 대기 후 같이 배포 됨. 제한사항 작업의 개수(progresses, speeds배열의 길이)는 100개 이하입니다. 작업 진도는 100 미만의 자연수입니다. 작업 속도는 100 이하의 자연수입니다. 배포는 하루에 한 번만 할 수 있으며, 하루의 끝에 이루어진다고 가정합니다. 예를 들어 진도율이 95%인 작업의 개발 속도가 하루에 4%라면 배포는 2일 뒤에 이루어집니다. 입출력 예 progresses speeds return [93,30,55] [1,30,5] [2,1] 코드 function solution(progresses, speeds) { //현재 작업률-index가 작을 수록 우선순위 높음, 진행속도 배열 let answer = []; //정답을 담을 배열 let need_days = []; //작업을 완료하기 위한 day를 담는 배열 const len = progresses.length; for (let i = 0; i < len; i ++) { //1. 작업을 완료하기 위한 날짜를 구하여 배열에 담는다.(소수점 올림하여 처리) need_days.push(Math.ceil((100 - progresses[i]) / speeds[i])); } let count = 0; //배포 시의 기능 개수 let max = 0; //작업의 필요한 Day중 가장 큰 값을 담는 변수 need_days.forEach((value, index) => { //배포 가능한 경우 if (value > max) { max = value; //index-0인

[프로그래머스] 프린터 javascript

[스택/큐] level2 프린터 javascript 조건 1. 인쇄 대기목록의 가장 앞에 있는 문서(J)를 대기목록에서 꺼냅니다. 2. 나머지 인쇄 대기목록에서 J보다 중요도가 높은 문서가 한 개라도 존재하면 J를 대기목록의 가장 마지막에 넣습니다. 3. 그렇지 않으면 J를 인쇄합니다. 제한사항 현재 대기목록에는 1개 이상 100개 이하의 문서가 있습니다. 인쇄 작업의 중요도는 1~9로 표현하며 숫자가 클수록 중요하다는 뜻입니다. location은 0 이상 (현재 대기목록에 있는 작업 수 - 1) 이하의 값을 가지며 대기목록의 가장 앞에 있으면 0, 두 번째에 있으면 1로 표현합니다. 입출력 예 priorities location return [2, 1, 3, 2] 2 1 [1, 1, 9, 1, 1, 1] 0 5 코드 function solution(priorities, location) { //중요도, 요청 문서 index let target_index = location; //user가 선택한 index let answer = 1; let first = -1; while (priorities.length > 0) { //1. 가장 앞에 있는 문서를 추출 first = priorities.shift(); //2. 중요도 높은 문서가 존재 시 뒤로 넣음 if (priorities.some((value, index) => value > first)) { priorities.push(first); } else { if (target_index === 0) { break; } else answer ++; } /*3. 사용자가 선택

마지막 문자가 개행 문자인 경우 무시되는 현상

마지막 문자가 개행문자인 경우 무시되는 현상 현상 HTML Tag의 마지막 문자가 단독으로 존재하는 개행문자인 경우 개행처리를 하지 않음 현상 확인 방법 DOM에 value 직접 셋팅 단독 개행문자(Enter) 단독 개행문자(br Tag) script를 사용하여 innerHTML의 value 변경 script 실행 \n이 마지막으로 변경 \r\n이 마지막으로 변경 br Tag가 마지막으로 변경 해결 방안 개행문자(\n, br tag, etc...)를 하나 더 추가하여 개행처리가 되도록 한다. br Tag 2번 사용 textarea tag를 사용 한다.(단일 개행문자 적용가능) 테스트 환경 IE11, Chrome, FF, Edge, Opera, Safari 기타 innerHTML만이 아닌 textcontent로 개행문자를 적용 시 동일하게 현상 발생.