์ฑ… ๋ฆฌ๋ทฐ/๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ)

[๋ฆฌํŒฉํ„ฐ๋ง 2ํŒ] 12.7 ์„œ๋ธŒํด๋ž˜์Šค ์ œ๊ฑฐํ•˜๊ธฐ

Rainbow๐ŸŒˆCoder 2022. 11. 24. 17:17
728x90

1. ์–ธ์ œ ์‚ฌ์šฉํ•˜๋ฉด ์ข‹์„๊นŒ

๋”์ด์ƒ ์“ฐ์ด์ง€ ์•Š๋Š” ์„œ๋ธŒํด๋ž˜์Šค์™€ ๋งˆ์ฃผํ•˜๋Š” ํ”„๋กœ๊ทธ๋ž˜๋จธ๋Š” ๊ฐ€์น˜ ์—†๋Š” ๊ฒƒ์„ ์ดํ•ดํ•˜๋А๋ผ ์—๋„ˆ์ง€๋ฅผ ๋‚ญ๋น„ํ•  ๊ฒƒ์ด๋‹ค.

์ด๋Ÿฐ ์ •๋„๊นŒ์ง€ ๋˜๋ฉด ์„œ๋ธŒํด๋ž˜์Šค๋ฅผ ์Šˆํผํด๋ž˜์Šค์˜ ํ•„๋“œ๋กœ ๋Œ€์ฒดํ•ด ์ œ๊ฑฐํ•˜๋Š” ๊ฒŒ ์ตœ์„ ์ด๋‹ค.

๋ถˆํ•„์š”ํ•œ ์„œ๋ธŒ ํด๋ž˜์Šค๋ฅผ ์ œ๊ฑฐํ•˜๊ณ , ๋Œ€์‹ ์— ์™ธ๋ถ€์—์„œ ์ „ํ˜€ ์•Œ ํ•„์š”์—†๋Š” ๋‚ด๋ถ€๋กœ์ง๋“ค์„ ์ž˜ ์บก์Аํ™”ํ•ด๋‘๊ณ , 

์™ธ๋ถ€์—์„œ ์‚ฌ์šฉํ•˜๊ธฐ ์‰ฝ๊ฒŒ create๋ผ๋Š” ํŒฉํ† ๋ฆฌ ๋ฉ”์†Œ๋“œ๋ฅผ ์ œ๊ณตํ•ด์ฃผ๊ณ , ๊ธฐํƒ€ ํ•„์š”ํ•œ ๋ฉ”์†Œ๋“œ๋ฅผ ์ž˜ ์ฑ™๊ฒจ์ฃผ๋„๋ก ํ•˜์ž. 

 

2. ์ ˆ์ฐจ

(1) ์„œ๋ธŒํด๋ž˜์Šค์˜ ์ƒ์„ฑ์ž๋ฅผ ํŒฉํ„ฐ๋ฆฌ ํ•จ์ˆ˜๋กœ ๋ฐ”๊พผ๋‹ค.

-> ์ƒ์„ฑ์ž๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ์ธก์—์„œ ๋ฐ์ดํ„ฐ ํ•„๋“œ๋ฅผ ์ด์šฉํ•ด ์–ด๋–ค ์„œ๋ธŒํด๋ž˜์Šค๋ฅผ ์ƒ์„ฑํ• ์ง€ ๊ฒฐ์ •ํ•œ๋‹ค๋ฉด ๊ทธ ๊ฒฐ์ • ๋กœ์ง์„ ์Šˆํผํด๋ž˜์Šค์˜ ํŒฉํ„ฐ๋ฆฌ ๋ฉ”์„œ๋“œ์— ๋„ฃ๋Š”๋‹ค.

(2) ์„œ๋ธŒํด๋ž˜์Šค์˜ ํƒ€์ž…์„ ๊ฒ€์‚ฌํ•˜๋Š” ์ฝ”๋“œ๊ฐ€ ์žˆ๋‹ค๋ฉด ๊ทธ ๊ฒ€์‚ฌ ์ฝ”๋“œ์— ํ•จ์ˆ˜ ์ถ”์ถœํ•˜๊ธฐ์™€ ํ•จ์ˆ˜ ์˜ฎ๊ธฐ๊ธฐ๋ฅผ ์ฐจ๋ก€๋กœ ์ ์šฉํ•˜์—ฌ ์Šˆํผํด๋ž˜์Šค๋กœ ์˜ฎ๊ธด๋‹ค. ํ•˜๋‚˜ ๋ณ€๊ฒฝํ•  ๋•Œ๋งˆ๋‹ค ํ…Œ์ŠคํŠธํ•œ๋‹ค.

(3) ์„œ๋ธŒํด๋ž˜์Šค์˜ ํƒ€์ž…์„ ๋‚˜ํƒ€๋‚ด๋Š” ํ•„๋“œ๋ฅผ ์Šˆํผํด๋ž˜์Šค์— ๋งŒ๋“ ๋‹ค.

(4) ์„œ๋ธŒํด๋ž˜์Šค๋ฅผ ์ฐธ์กฐํ•˜๋Š” ๋ฉ”์„œ๋“œ๊ฐ€ ๋ฐฉ๊ธˆ ๋งŒ๋“  ํƒ€์ž… ํ•„๋“œ๋ฅผ ์ด์šฉํ•˜๋„๋ก ์ˆ˜์ •ํ•œ๋‹ค.

(5) ์„œ๋ธŒํด๋ž˜์Šค๋ฅผ ์ง€์šด๋‹ค.

(6) ํ…Œ์ŠคํŠธํ•œ๋‹ค.

 

3.  ๋ฆฌํŒฉํ† ๋ง ์ „ ์ „์ฒด ์ฝ”๋“œ

class Person {
	#name;
	constructor(name) {
		this.#name = name;
	}

	get name() {
		return this.#name;
	}

	get genderCode() {
		return 'X';
	}
}

class Male extends Person {
	get genderCode() {
		return 'M';
	}
}

class Female extends Person {
	get genderCode() {
		return 'F';
	}
}

function loadFromInput(data) {
	const result = [];
	data.forEach((record) => {
		let person;
		switch (record.gender) {
			case 'M':
				person = new Male(record.name);
				break;
			case 'F':
				person = new Female(record.name);
				break;
			default:
				person = new Person(record.name);
		}
        result.push(person);
	});
    return result;
}

const people = loadFromInput([
	{ name: '์€ํ•˜', gender: 'F' },
	{ name: '์‹ ๋น„', gender: 'F' },
	{ name: '์ง„์šฐ', gender: 'M' },
	{ name: 'ํƒœํ˜„', gender: 'M' },
	{ name: 'ํƒœ์—ฐ', gender: 'F' }
]);

์ถœ๋ ฅ๊ฐ’

4.  ๋ฆฌํŒฉํ† ๋ง ํ›„ ์ „์ฒด ์ฝ”๋“œ

class Person {
	#name;
	#genderCode;
	constructor(name, genderCode) {
		this.#name = name;
		this.#genderCode = genderCode;
	}

	get name() {
		return this.#name;
	}

	get genderCode() {
		return this.#genderCode;
	}

	get isMale() {
		return this.#genderCode === 'M';
	}

	static create(record) {
		switch (record.gender) {
			case 'M':
				return new Person(record.name, 'M');
				break;
			case 'F':
				return new Person(record.name, 'F');
				break;
			default:
				return new Person(record.name, 'X');
				break;
		}
	}
}

const people = loadFromInput([
	{ name: '์€ํ•˜', gender: 'F' },
	{ name: '์‹ ๋น„', gender: 'F' },
	{ name: '์ง„์šฐ', gender: 'M' },
	{ name: 'ํƒœํ˜„', gender: 'M' },
	{ name: 'ํƒœ์—ฐ', gender: 'F' }
]);

function loadFromInput(data) {
	const result = [];
	data.forEach((element) => {
		result.push(Person.create(element));
	});
	return result;
}

const numberOfMales = people.filter((p) => p.isMale).length;
console.log(numberOfMales);

์ถœ๋ ฅ๊ฐ’

 

728x90