-
Notifications
You must be signed in to change notification settings - Fork 2
21-mj010504 #78
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. Weβll occasionally send you account related emails.
Already on GitHub? Sign in to your account
21-mj010504 #78
Conversation
flydongwoo
left a comment
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
κ²μ κ·μΉμ μ΄ν΄λ₯Ό μλͺ»ν΄μ μ’ λΉλΉ λλ©΄μ ν΄λ§Έλ€μ νν
νλ‘κ·Έλλ¨Έμ€λ ν¨μλ₯Ό μμ±νλ κ²μ΄λ€λ³΄λ μ’ λ§μ΄ λ² μ°¨λ€μ
λ¨μ ꡬνμΌλ‘ νμμ΅λλ€
ν΄κ°μ μ¬μ΄λ νμ μΌμ μ΄ κ²ΉμΉλ€λ³΄λ μ PRμ΄ λ무 λ§μ΄ λ°λ Έλ€μ μ΄μ¬ν μ¬λ €λ³΄λλ‘ νκ² μ΅λλ€!
νΌμμ νλ ν±νν
#include <vector>
#include <string>
using namespace std;
static bool win(const vector<string>& b, char ch) {
for (int i = 0; i < 3; i++) {
if (b[i][0] == ch && b[i][1] == ch && b[i][2] == ch) {
return true;
}
if (b[0][i] == ch && b[1][i] == ch && b[2][i] == ch) {
return true;
}
}
if (b[0][0] == ch && b[1][1] == ch && b[2][2] == ch) {
return true;
}
if (b[0][2] == ch && b[1][1] == ch && b[2][0] == ch) {
return true;
}
return false;
}
int solution(vector<string> board) {
int cntO = 0;
int cntX = 0;
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++) {
if (board[i][j] == 'O') {
cntO++;
} else if (board[i][j] == 'X') {
cntX++;
}
}
}
if (!(cntO == cntX || cntO == cntX + 1)) {
return 0;
}
bool winO = win(board, 'O');
bool winX = win(board, 'X');
if (winO && winX) {
return 0;
}
if (winO && cntO != cntX + 1) {
return 0;
}
if (winX && cntO != cntX) {
return 0;
}
return 1;
}|
λ¬Έμ λ₯Ό μ½κ³ κ·μΉμ±μ νλ¨ν λ€ λ°λ‘μ²λ¦¬ 쑰건μ μ ꡬμνλ λ²μ μ°μ΅νλ λ¬Έμ λ€μ. μ λ λ¬Έμ μμ μ΄λ κ² μ 보λ₯Ό λ½μλμ΅λλ€.
3 * 3 보λνμ΄λκΉ λ¨μ 빑ꡬνμΌλ‘ μ²λ¦¬νμ΅λλ€. λ―Όμ€λ μ½λλ₯Ό 보λ μμ² κΉλνλ€μ. κ°λ₯ν κ²½μ°μ μμ λν΄μ νμνμ μ λ§μ§λ§ λΆλΆμ΄ λ κΉλν κ² κ°μ΅λλ€. μ λ λΆκ°λ₯ν κ²½μ°μ μλ₯Ό νμνλ €λ€ λ³΄λ λ€μͺ½ 쑰건λΆλΆλ λμ‘ν΄μ§ λλμ΄ λλ€μ. μλλ μ μΆ μ½λμ λλ€. κ³ μνμ ¨μ΄μ! νΌμμ νλ ν±νν / c++#include <string>
#include <vector>
using namespace std;
int solution(vector<string> board) {
int answer = 1;
int ocount = 0;
int xcount = 0;
for(int i = 0; i < 3; i++)
{
for(int j = 0; j < 3; j++)
{
if(board[i][j] == 'O')
{
ocount++;
}
else if(board[i][j] == 'X')
{
xcount++;
}
}
}
if(!((ocount == xcount) || (ocount - 1 == xcount)))
{
answer = 0;
}
bool isowin = false;
bool isxwin = false;
// κ°λ‘λΆν° κ²μ¬
for(int i = 0; i < 3; i++)
{
if(board[i][0] == board[i][1] && board[i][1] == board[i][2])
{
if(board[i][0] == 'O')
{
isowin = true;
}
else if(board[i][0] == 'X')
{
isxwin = true;
}
}
}
// μΈλ‘
for(int i = 0; i < 3; i++)
{
if(board[0][i] == board[1][i] && board[1][i] == board[2][i])
{
if(board[0][i] == 'O')
{
isowin = true;
}
else if(board[0][i] == 'X')
{
isxwin = true;
}
}
}
// λκ°
if(board[0][0] == board[1][1] && board[1][1] == board[2][2])
{
if(board[0][0] == 'O')
{
isowin = true;
}
else if(board[0][0] == 'X')
{
isxwin = true;
}
}
if(board[0][2] == board[1][1] && board[1][1] == board[0][2])
{
if(board[0][2] == 'O')
{
isowin = true;
}
else if(board[0][2] == 'X')
{
isxwin = true;
}
}
if(isowin && isxwin)
{
answer = 0;
}
if(isowin)
{
if(ocount - 1 != xcount)
{
answer = 0;
}
}
else if(isxwin && !isowin)
{
if(xcount != ocount)
{
answer = 0;
}
}
return answer;
}
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
μ λ μ²μμ μ¬λ°λ₯Έ κ²½μ°κ° λ λ§μκΉ, μ¬λ°λ₯΄μ§ μμ κ²½μ°κ° λ λ§μκΉλ₯Ό κ³ λ―Όνλ€κ° μ¬λ°λ₯΄μ§ μμ κ²½μ°λ₯Ό μ°Ύλ λ°©ν₯μΌλ‘ νμλλ° λμμ λ μ€ λΉκ³ κ° λμ€λ μν©μ κ³ λ €νμ§ λͺ»νμ΅λλ€.
μ¬μ€ μ΄ λ¬Έμ λ μ¬λ°λ₯Έ κ²½μ°λ₯Ό μ°Ύλ κ² λ κ°λ¨νλ° O β X β O β X μμμ΄λ―λ‘ λ°λμ Oμ κ°μ >= Xμ κ°μ μμ μ μκ°νλ©΄ λ€μκ³Ό κ°μ΄ μμ½λ©λλ€.
- O κ°μκ° X κ°μμ κ°μ λ, O λΉκ³ κ° μλλΌλ©΄ μ±κ³΅
- O κ°μκ° X κ°μλ³΄λ€ 1κ° λ§μ λ, X λΉκ³ κ° μλλΌλ©΄ μ±κ³΅
- μ΄μΈμλ λͺ¨λ μ€ν¨
μ½λλ λ€μκ³Ό κ°μ΅λλ€.
from collections import Counter
def solution(board):
# Oμ X κ°μ
count = Counter("".join(board))
# μΈλ‘μ€μ κ°λ‘μ€λ‘ λ°κΎΌ λ°°μ΄
tranposed = []
for j in range(3):
new_row = ""
for i in range(3):
new_row += board[i][j]
tranposed.append(new_row)
tmp = board + tranposed
# λκ°μ
dia1 = board[0][0] + board[1][1] + board[2][2]
tmp.append(dia1)
dia2 = board[0][2] + board[1][1] + board[2][0]
tmp.append(dia2)
# λΉκ³ κ°μ
o_win = tmp.count("OOO")
x_win = tmp.count("XXX")
# O κ°μκ° X κ°μμ κ°μλ, O λΉκ³ κ° μλλΌλ©΄ μ±κ³΅
if count['O'] == count['X'] and o_win == 0:
return 1
# O κ°μκ° X κ°μλ³΄λ€ 1κ° λ§μλ, X λΉκ³ κ° μλλΌλ©΄ μ±κ³΅
if count['O'] - count['X'] == 1 and x_win == 0:
return 1
# μ΄μΈμλ λͺ¨λ μ€ν¨
return 0μ λ μ 체 λ°°μ΄μμ O κ°μμ X κ°μλ Counterλ‘ κ΅¬νκ³ , λΉκ³ κ°μλ λͺ¨λ μΈλ‘μ€μ κ°λ‘μ€λ‘ λ°κΎΈκ³ , λκ°μ μ νλμ½λ©μΌλ‘ μ²λ¦¬ν λ€, OOOμ XXXμ κ°μλ₯Ό ꡬνλ λ°©λ²μΌλ‘ νμμ΅λλ€.
λ©μλ λ°©λ²μ μλμ§λ§... μΆ©λΆν 빨리 ν μ μλ λ°©λ²μ
λλ€.
λ¬Έμ νΌλ€κ³ μκ³ νμ
¨μ΅λλ€!
μ κ° μ΄λ² μ£Ό λ΄λ΄ μ‘°κΈ λ°λΉ μ... λ¨μ PR λ° λ¦¬λ·°λ λ€μμ£Όμ λͺ°μμ λ€ μΉμ°κ² μ΅λλ€!
π λ¬Έμ λ§ν¬
https://school.programmers.co.kr/learn/courses/30/lessons/160585#qna
βοΈ μμλ μκ°
30λΆ
β¨ μλ μ½λ
λ₯Ό μ μΈν λͺ¨λ κ²½μ°λ λΆκ°λ₯ν κ²½μ°λ‘ μ²λ¦¬νμ΅λλ€.
π μλ‘κ² μκ²λ λ΄μ©