인프런 커뮤니티 질문&답변

thummim님의 프로필 이미지
thummim

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

1G (백준 9996번)문제 반례 받을 수 있을까요?

작성

·

310

0

최대한 큰돌님 소스 안보고 혼자 하려고 했는데 큰돌님 소스 보고 나니까 너무 지저분하고 정답도 아니고 그렇네요 ㅠㅠ
 
반례와 소스코드 문제점 한 번 봐주실 수 있을까요?
 
#include<bits/stdc++.h>
using namespace std;

int main()
{
	int N;
	string pattern, filename, first, last;
	int size;

	cin >> N;
	cin >> pattern;

	size = pattern.size() - 1; // 패턴의 크기 저장

	if (pattern[0] == 42 || pattern[size] == 42) //패턴의 시작과 끝이 *이면 안되므로 리턴
		return 0;

	first = pattern[0];
	last = pattern[size];

	for (int i = 0; i < N; i++)
	{
		cin >> filename;
		int size2 = filename.size() - 1;
		string first2, last2;

		first2 = filename[0];
		last2 = filename[size2];

		if (first == first2 && last == last2)
			cout << "DA" << endl;
		else
			cout << "NE" << endl;
	}

	return 0;
}

답변 1

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요. ㅎㅎ 문제점은 다음과 같아요.

 

1. 문제를 제대로 안 읽음. 

문제 : 

둘째 줄에는 패턴이 주어진다. 패턴은 알파벳 소문자와 별표(아스키값 42) 한 개로 이루어져 있다. 문자열의 길이는 100을 넘지 않으며, 별표는 문자열의 시작과 끝에 있지 않다. 

분명 문제에는 별표가 끝에 위치하지 않는다. 라고 써져 있는데

 

if (pattern[0] == 42 || pattern[size] == 42) //패턴의 시작과 끝이 *이면 안되므로 리턴

return 0;

 

쓸데 없는 코드가 있죠?

 

2, 그냥 틀린 코드. 

예를 들어 ab*ab라는게 나올 수 있고

adddb라는 예제가 나올 수도 있는데 (이게 반례에요.)

왜 처음과 끝만 맞으면 되게 하신건가요?

이 문제에서 "별표를 제외한 문자열은 한글자"로 정해져있나요? 아니죠? ㅎㅎ

 

감사합니다. 

강사 큰돌 올림.

thummim님의 프로필 이미지
thummim
질문자

감사합니다!!

thummim님의 프로필 이미지
thummim

작성한 질문수

질문하기