1강 숫자야구 문제 질문
안녕하세요,
알려주신 대로 코드를 작성하였는데 결과가 계속 안나오네요. 혹시 어떤 부분에서 문제가 있는지 알 수 있을까요?
n=int(input())
result=0 # 가능한 결과의 개수
mycon=[list(input().split()) for _ in range(n)]
for a in range(1,10):
for b in range(1,10):
for c in range(1,10):
count=0
if a==b or b==c or a==c:
continue
for i in range(n):
strike_count=0
ball_count=0
#nowcon은 각 조건을 담은 리스트
nowcon=mycon[i]
if str(a)==nowcon[0][0]:
strike_count+=1
if str(b)==nowcon[0][1]:
strike_count+=1
if str(c)==nowcon[0][2]:
strike_count+=1
if str(a) in nowcon[0]:
ball_count+=1
if str(b) in nowcon[0]:
ball_count+=1
if str(c) in nowcon[0]:
ball_count+=1
ball_count-=strike_count
if strike_count==nowcon[1] and ball_count==nowcon[2]:
count+=1
if count==n:
result+=1
print(result)
감사합니다
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
Emilie 님의 숫자야구 문제 관련 질문에 대해, 과거에 비슷한 문제를 질문한 수강생들의 질문을 검토해 보았습니다. 잠재적 오류나 흔히 발생하는 실수를 파악하여 코드를 검토해 볼 필요가 있습니다.
해당 강의의 다른 수강생들이 질문한 내용 중 가장 유사한 질문은 ‘백준 2503 숫자야구 문제 어떤 부분이 잘 못되었는지 모르겠습니다’ 입니다. 이 글에서는 자주 발생할 수 있는 실수 교정 방법에 대한 설명을 확인할 수 있습니다. 예를 들어 아래와 같은 실수가 있을 수 있습니다:
0이 포함되지 않아야 하는 경우를 포함시키고 있는지 확인합니다.

strike와ball을 반대로 입력 받고 있지는 않은지 확인합니다.
+=와=+처럼 오타가 있는지 꼼꼼히 검토합니다.
Emilie 님의 코드 내용을 기반으로, 이전 질문에서 지적된 오류들이 현재 코드에도 존재하는지 확인해 보세요. 특히 변수 할당, 조건문 검증, 그리고 입력 값을 올바르게 처리하고 있는지 점검이 필요해 보입니다. 또한, 이전 질문에 달린 지식공유자의 답변이 해결의 실마리를 제공할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
0
알려주신 대로 0을 포함해서 코드를 작성했는데 원하는 결과가 나오지 않습니다.
n=int(input())
result=0 # 가능한 결과의 개수
mycon=[list(input().split()) for _ in range(n)]
for a in range(1,10):
for b in range(10):
for c in range(10):
count=0
if (a==b or b==c or a==c):
continue
for i in range(n):
strike_count=0
ball_count=0
#nowcon은 각 조건을 담은 리스트
nowcon=mycon[i]
if str(a)==nowcon[0][0]:
strike_count+=1
if str(b)==nowcon[0][1]:
strike_count+=1
if str(c)==nowcon[0][2]:
strike_count+=1
# 볼 카운트=볼 카운트-스트라이크 카운트
if str(a)==nowcon[0][1] or str(a)==nowcon[0][2] :
ball_count+=1
if str(b)==nowcon[0][0] or str(a)==nowcon[0][2]:
ball_count+=1
if str(c)==nowcon[0][0] or str(a)==nowcon[0][1]:
ball_count+=1
if strike_count==nowcon[1] and ball_count==nowcon[2]:
count+=1
if count==n:
result+=1
print(result)
1
안녕하세요? 답변이 늦어서 죄송합니다...!
파이썬 코드의 경우 인덴트가 문법에서 중요한 부분을 차지하고 있다보니, 올려주신 코드로는 파악이 어려운 부분이 다소 있습니다 ㅠ 혹시 실례가 되지 않는다면 코드 블럭을 이용해서 코드를 한 번 더 올려주실 수 있으실까요?
일단 현재 보이는 바로는 첫번째 0은 기존에 작성하셨던 것처럼 포함되지 않아야 하는 부분이 맞는데, 이번에 작성하신 코드의 경우 b, c에서 0을 포함하도록 수정하신 것 같습니다...!
그리고 두번째로
if str(a)==nowcon[0][1] or str(a)==nowcon[0][2] :
ball_count+=1
if str(b)==nowcon[0][0] or str(a)==nowcon[0][2]:
ball_count+=1
if str(c)==nowcon[0][0] or str(a)==nowcon[0][1]:
ball_count+=1이 부분에서 a, b, c가 적절하게 사용되었는지 확인하실 필요도 있어 보입니다! a, b, c가 각각 두번씩 비교가 되는 부분일텐데, 상기 코드에서는 a가 4번, b와 c가 각각 1번씩 비교가 되는 것 같습니다!
세번째로 문자열과 수와 같은 타입의 비교가 적절한지도 생각해 보실 필요가 있어 보입니다!
감사합니다 🙂
dp[x]가 최대값이라고 확신할수 있는 이유
0
45
1
1090번 문제 질문
0
150
1
유니온파인드
0
112
1
투포인터 25:15 질문
1
128
1
#1090번 문제 반례가 궁금합니다.
0
148
1
예제코드 자바입니다
1
186
1
정수론 파트 #2247 문제에 대한 질문입니다!
0
102
0
코드 오류
0
185
1
2강 정수론 문제3 #1407 질문
0
127
0
이차원 배열 (int형)dp로 0 혹은 -1로 체크하는 방법 말고 boolean형 배열로 체크해서 바로 리턴해줄 수 없나요?
0
154
0
1717번 최적화
0
112
0
백준 22988 문제 질문
1
193
2
[Python] 백준 1090번 문제
1
226
3
강의자료에서
1
162
2
2503 문제 제한 조건 질문!
1
249
2
백준 22988 번 문제
1
193
1
추가 강의 순서
1
180
2
(*문제 풀이)1090 테스트케이스 1번 C++
1
221
2
7강 RGB 색칠하기 질문 있습니다.
1
160
2
정수론 약수 빠르게 구하기 질문
1
257
1
1090 문제의 2, 3번째 아이디어는 결국 같은거 아닌가요?
1
373
2
1090 문제 관련하여 맨해튼 거리 최솟값에 대해 질문 있습니다.
1
223
2
누적합 문제 3번 질문
1
216
2
기억 ( 누적합 ) 강의 11660 문제
1
163
2





