문제 번호 1492. -- 2020년 2학기 객체기반SW설계 기말고사 - 2번

1492: 2020년 2학기 객체기반SW설계 기말고사 - 2번

시간 제한: 1 Sec  메모리 제한: 128 MB
제출: 340  해결 문제 수: 167
[제출][채점 상황 열람][게시판]

문제 설명


class Car의 object는 method addName(string s )을 이용하여
인수로 주어지는 string을 내부에 저장한다.
그리고 method vectorgetReverseSortedNames( )를 호출하면
저장된 s들이 내림차순(사전 역순)으로 저장된 vector를 반환한다.

Car object의 한 가지 특별한 점은 '-'(minus) 연산을 지원한다는 것이다.
예를 들어 Car object c1에 string aaa, bbb가 저장되어 있고,
다른 Car object c2에 string bbb가 저장되어 있을 경우,
Car d = c1 - c2;를 수행하면
Car object d에는 string aaa만 저장된다.
즉, '-' operator는 두 object가 공통으로 가지고 있는 string을 앞의 object가 가지고 있는 string에서
제거한 후, 새로운 object에 그 string들만 넣어서 만든다.
한 가지 예를 더 들면,
c1 { aaa, bbb, ccc, ddd } - c2 { bbb, ccc} = d {aaa, ddd}가 된다.

위의 조건을 만족하는 class Car를 아래의 표시부분에 작성하시오.
필요한 헤더 파일들을 include하고, 표시된 선 아래 부분은 수정하지 않는다.
힌트: class Car가 operator overloading을 지원하도록 한다


/*
   필요한 header를 include 하시오.
*/


using namespace std;


/*

    class Car를 정의하시오.
	
	method void addName(string s ) : 인수 s를 instance 내에 저장한다.
	
	method vector<string> getReverseSortedNames( ): 
	   저장된 s들을 내림차순 (사전역순)으로 저장한 vector를 반환한다.
	   
	'-' operator를 지원해야 한다.

*/


//------------------------------------------------------------
// 여기서부터는 수정하지 마시오
//------------------------------------------------------------
int main()
{
	Car c;

	string name;

	while (true)
	{
		getline(cin, name);

		if (name == "END")
		{
			break;
		}
		else
		{
			c.addName(name);
		}
	}

	Car d;
	while (true)
	{
		getline(cin, name);

		if (name == "END")
		{
			break;
		}
		else
		{
			d.addName(name);
		}
	}

	Car e = c - d;

	auto res = e.getReverseSortedNames();
	for (auto& e : res)
	{
		cout << e << " ";
	}

	return 0;
}

입력

출력

도움말

출처

[제출][채점 상황 열람]