: 내장 객체의 메서드를 사용해서 문제를 해결하였다.

 


✔ 학습한 내용

 

  • sort()

: Array.prototype.sort()

: 원 배열을 정렬한다. 복사본이 만들어지는 것이 아님에 주의하자


매개변수

  1.  compareFunction

: 정렬 순서를 정의하는 함수.

생략하면 배열의 요소를 문자열로 변환하여, 각 문자의 유니 코드 코드 포인트 값에 따라 정렬된다. 즉, 숫자를 정렬하고자 할 때는 필수로 작성해주어야 한다.

 

위 함수의 반환값에 따른 sort()의 실행 결과는 다음과 같다.

 

반환값 < 0 : a가 앞, b가 뒤에 위치

반환값 = 0 : 순서 변경 없음

반환값 > 0 : a가 뒤, b가 앞에 위치

 

let num = [1, 3, 20, 4];

console.log(num.sort());	// output: [ 1, 20, 3, 4 ]

// 오름차순
console.log(num.sort((a, b) => a - b));		// output: [ 1, 3, 4, 20 ]

// 내림차순
console.log(num.sort((a, b) => b - a));		// output: [ 20, 4, 3, 1 ]

 

  • slice()

: Array.prototype.slice()

: 어떤 배열의 시작 인덱스(s)부터 끝 인덱스(e)까지의 요소로 새로운 배열을 반환한다.


매개변수

  1. s  : 추출할 첫 번째 요소의 인덱스. 생략하면 0 부터 시작한다.
  2. e : 추출을 종료할 요소의 인덱스. 해당 인덱스의 요소는 추출에서 제외한다.

 

num = [1, 2, 3, 4, 5];

console.log(num.slice(2));	// output: [ 3, 4, 5 ]

console.log(num.slice(1,3));	// output: [ 2, 3 ]

console.log(num.slice());	// output: [ 1, 2, 3, 4, 5 ]

: reserve 배열과 lost 배열에 따라 학생들의 상태를 저장한 배열을 만들어, 주어진 조건에 따라 계산해주었다.


✔ 학습한 내용

 

  •  filter()

: Array.prototype.filter()

: 주어진 함수에 참인 모든 요소를 모아 새로운 배열로 반환한다. 그런 요소가 없다면, 빈 배열을 반환한다.

 

const arr = [4, 6, 1, 7, 2];

const result = arr.filter(element => element > 5);

console.log(result);	// output: [6, 7]

 

  •  find()

: Array.prototype.find()

: 주어진 함수에 참인 첫 번째 요소를 반환한다. 그런 요소가 없다면, undefined을 반환한다.

 

const arr = [4, 6, 1, 7, 2];

const result = arr.find(x => x > 5);

console.log(result);	// output: 6

 

  •  Math.abs()

: 주어진 숫자 매개변수의 절댓값을 반환한다.

 

function minus(a, b) {
	return Math.abs(a - b);
}

console.log(minus(2, 4));	// output: 2
console.log(minus(3, 6));	// output: 3

 

: 단계에 대한 정보를 구현하면 되는 문제다.


학습한 내용

 

  •  메소드 체이닝
new_id = new_id.toLowerCase();

new_id = new_id.replace(/[~!@#$%^&*\(\)=+\[\]\{\}:?,\<\>\\\/]/g, '');

new_id = new_id.replace(/\.{2,}/g, '.');

answer = new_id;

// 위 코드를 '메소드 마이닝'을 이용해 아래와 같이 간단히 표현할 수 있다.
const answer = new_id
              .toLowerCase()
              .replace(/[~!@#$%^&*\(\)=+\[\]\{\}:?,\<\>\\\/]/g, '')
              .replace(/\.{2,}/g, '.');

 

  •  charAt()

: String.prototype.charAt()

: 문자열에서 특정 인덱스에 위치하는 유니코드 단일문자를 반환한다.

 

const str = "hello";

console.log(str.charAt(0));	// "h" 출력
console.log(str.charAt(4));	// "o" 출력

 

  •  정규 표현식 (정규식)

: 문자열에 나타는 특정 문자 조합과 대응시키기 위해 사용되는 패턴이다.

 

const arr = ".example.";

// ^\. : 문자열 앞부터 진행하고, 처음 찾은 '.'을 삭제한다.

console.log(arr.replace(/^\./g, ''));	// "example." 출력

// \.$ : 문자열 뒤부터 진행하고, 처음 찾은 '.'을 삭제한다.

console.log(arr.replace(/\.$/g, ''));	// ".example" 출력

Q. 세준이는 양수와 +, -, 그리고 괄호를 가지고 식을 만들었다. 그리고 나서 세준이는 괄호를 모두 지웠다.

그리고 나서 세준이는 괄호를 적절히 쳐서 이 식의 값을 최소로 만들려고 한다.

괄호를 적절히 쳐서 이 식의 값을 최소로 만드는 프로그램을 작성하시오.

 

입력.

첫째 줄에 식이 주어진다. 식은 ‘0’~‘9’, ‘+’, 그리고 ‘-’만으로 이루어져 있고, 가장 처음과 마지막 문자는 숫자이다. 그리고 연속해서 두 개 이상의 연산자가 나타나지 않고, 5자리보다 많이 연속되는 숫자는 없다. 수는 0으로 시작할 수 있다. 입력으로 주어지는 식의 길이는 50보다 작거나 같다.

 

출력.

첫째 줄에 정답을 출력한다.

 


 

※ " 유셩장 " 블로그를 참고했다.

 

숫자를 임시 저장하기 위한 변수 tmp를 반복문에 들어가기 전에 초기화 해주지 않았다.

그 결과 다른 곳을 삽질하느라 오답이 많았다.

 

// 취소값을 만들기 위해 문자 - 전까지 숫자들을 더해준다. !

 

#include <iostream>
#include <cstring>

using namespace std;

int main() {
	int i, j, tmp, sum, len, ans;
	int num[50] = {0, };
	char s[51];
	
	cin >> s;
	
	len = strlen(s);
	
	j = 0;
	sum = 0; tmp = 0;
	
	for (i = 0; i < len; i++) {
		if (s[i] == '+') {
			sum += tmp;
			tmp = 0;
		} else if (s[i] == '-') {
			sum += tmp;
			num[j] = sum;
			j++;
			sum = 0;
			tmp = 0;
		} else {
			tmp *= 10;
			tmp += (s[i] - '0');
		}
	}
	
	sum += tmp;
	num[j] = sum;
	
	ans = num[0];
	
	for (i = 1; i < 50; i++) {
		ans -= num[i];
	}
	
	cout << ans << endl;
	
	return 0;
}

 

'백준 알고리즘' 카테고리의 다른 글

[python] 10171번  (0) 2020.12.27
[Python] 10718번  (0) 2020.12.27
[C언어] 2884번  (0) 2020.11.10
[C언어] 2606번  (0) 2020.09.18
[C언어] 2847번  (0) 2020.09.02

Element 클래스의 메소드 중 하나로, 파라미터로 받은 특정 selector 에 해당하는 첫 번째 자손 element를 반환 한다. 그러나 일치하는 element를 찾을 수 없으면 null 을 반환한다.

 


 

🌈 Example

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Example</title>
        <script src="main.js" defer></script>
    </head>
    <body>
        <h1>Hello</h1>
        <h1>World</h1>
    </body>
</html>
//javascript

'use strict'

console.log(document.querySelector('h1'));

 

위 코드를 보면, <h1> 코드가 2 줄 존재하지만 querySelector() 는 조건에 맞은 selector 집합 중에서 첫 번째 자손 element를 반환하기 때문에 결과는 다음과 같다.

 

Q. 아래 예제와 같이 고양이를 출력하시오.

 

입력.

없음.

 

출력.

고양이를 출력한다.

 

 


 

문자열을 여러 줄 출력하는 방법을 사용하였다.

 

※  \ ( 백슬래시 ) 앞에 " 혹은 ' 가 있으면, 확장 문자 ( \\ ) 를 사용하지 않아도 정상적으로 출력 된다.

 

print("""\    /\\
 )  ( ')
(  /  )
 \(__)|""")

 

※ 특수 문자를 사용하지 않으면, 첫 따옴표 앞에 r을 붙여서 날 문자열로 바꿔준다.

print(r"""\    /\
 )  ( ')
(  /  )
 \(__)|""")

 

'백준 알고리즘' 카테고리의 다른 글

[C++] 1541번  (0) 2021.03.11
[Python] 10718번  (0) 2020.12.27
[C언어] 2884번  (0) 2020.11.10
[C언어] 2606번  (0) 2020.09.18
[C언어] 2847번  (0) 2020.09.02

Q. ACM-ICPC 인터넷 예선, Regional, 그리고 World Finals까지 이미 2회씩 진출해버린 kriii는 미련을 버리지 못하고 왠지 모르게 올 해에도 파주 World Finals 준비 캠프에 참여했다.

대회를 뜰 줄 모르는 지박령 kriii를 위해서 격려의 문구를 출력해주자.

 

입력.

본 문제는 입력이 없다.

 

출력.

두 줄에 걸쳐 "강한친구 대한육군"을 한 줄에 한 번씩 출력한다.

 


 

두 줄 이상의 문자열을 출력하는 방법을 사용한다.

 

python은 문자열을 큰 따옴표나 작은 따옴표를 삼중으로 감싸준다.

 

print('''강한친구 대한육군
강한친구 대한육군''')

 

'백준 알고리즘' 카테고리의 다른 글

[C++] 1541번  (0) 2021.03.11
[python] 10171번  (0) 2020.12.27
[C언어] 2884번  (0) 2020.11.10
[C언어] 2606번  (0) 2020.09.18
[C언어] 2847번  (0) 2020.09.02

Q. 상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다.

상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다.

이런 상근이를 불쌍하게 보던, 창영이는 자신이 사용하는 방법을 추천해 주었다.

바로 "45분 일찍 알람 설정하기"이다.

이 방법은 단순하다. 원래 설정되어 있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘 것이기 때문이다. 이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다.

현재 상근이가 설정한 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.

 

입력.

첫째 줄에 두 정수 H와 M이 주어진다. (0 ≤ H ≤ 23, 0 ≤ M ≤ 59) 그리고 이것은 현재 상근이가 설정한 놓은 알람 시간 H시 M분을 의미한다.

입력 시간은 24시간 표현을 사용한다. 24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다. 시간을 나타낼 때, 불필요한 0은 사용하지 않는다.

 

출력.

첫째 줄에 상근이가 창영이의 방법을 사용할 때, 설정해야 하는 알람 시간을 출력한다. (입력과 같은 형태로 출력하면 된다.)

 


 

기본적으로 입력 받은 시간 중 변수 M에서 45를 뺀 결과를 구해야 한다.

 

여기서 주의해야 하는 곳은 (1-1) 변수 M의 값이 45 보다 작은 경우, (1-2)  변수 M에서 값을 빼기 위해, 변수 H의 값에서 1을 뺀 값이 0보다 작아지는 경우 이다.

 

위 두 경우를 조건문으로 한다.

 

#include <stdio.h>

int main(void) {
	int h, m;

	scanf("%d %d", &h, &m);

	if (m > 45)
		m -= 45;
	else {
		if (h == 0)
			h += 24;
		h--;
		m += 60;
		m -= 45;
	}

	printf("%d %d\n", h, m);
	
	return 0;
}

 

'백준 알고리즘' 카테고리의 다른 글

[python] 10171번  (0) 2020.12.27
[Python] 10718번  (0) 2020.12.27
[C언어] 2606번  (0) 2020.09.18
[C언어] 2847번  (0) 2020.09.02
[C언어] 12015번  (0) 2020.08.30

+ Recent posts