С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 07.02.2012
Сообщений: 37

Крестики нолики

27.04.2012, 12:22. Показов 1565. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Никак не получается определить, кто победил, всегда выводит ничью. Почему?

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#include <iostream>
#include <conio.h>
using namespace std;
 
char board[9] = {'-', '-', '-', '-', '-', '-', '-', '-', '-'};
 
void print_board(){
    cout <<"-"<<board[6]<<"-|-"<<board[7]<<"-|-"<<board[8]<<"-"<<endl;
    cout <<"-"<<board[3]<<"-|-"<<board[4]<<"-|-"<<board[5]<<"-"<<endl;
    cout <<"-"<<board[0]<<"-|-"<<board[1]<<"-|-"<<board[2]<<"-"<<endl;
}
 
int get_move(){
 
    int move;
    cout <<"Подсказка\n";
    cout <<"-7-|-8-|-9-"<<endl;
    cout <<"-4-|-5-|-6-"<<endl;
    cout <<"-1-|-2-|-3-"<<endl;
    cout <<"\n";
    
    cout <<"Игровое поле:"<<endl;
    print_board();
    cout <<"\nВаш ход: ";
    cin >>move;
 
    while (move >9||move<1||board[move-1]!='-') {
        cout <<"Пожалуйста, сделайте правильный ход (1-9)\n";
        cin >>move;
}
    
    return move;
}
 
void check(){
 
    if(board[6]==board[7]==board[8]){cout<<"Победили "<<board[6]<<" .";}
    else if(board[3]==board[4]==board[5]) {cout<<"Победили "<<board[3]<<" .";}
     else if(board[0]==board[1]==board[2]) {cout<<"Победили "<<board[0]<<" .";}
     else if(board[6]==board[3]==board[0]) {cout<<"Победили "<<board[6]<<" .";}
     else if(board[7]==board[4]==board[1]) {cout<<"Победили "<<board[7]<<" .";}
     else if(board[8]==board[5]==board[2]) {cout<<"Победили "<<board[8]<<" .";}
     else if(board[6]==board[4]==board[2]) {cout<<"Победили "<<board[6]<<" .";}
     else if(board[8]==board[4]==board[0]) {cout<<"Победили "<<board[8]<<" .";}
     else cout <<"Ничья."<<endl; 
}
 
int main()
{
    setlocale (LC_ALL, "Russian");
 
    for (int i=0; i<5; i++){
 
        int move=get_move();
 
        if (i%2) {board[move-1]='O';}
        else    {board[move-1]='X';}
        //cout <<"Игровое поле: "<<endl;
        //print_board();
        cout <<"\n\n";
    }
 
    //cout <<"Победили "<<check()<<" .\n";
 
    cout <<"Итоговое игровое поле: \n";
    print_board();
    check();
 
    getch();
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.04.2012, 12:22
Ответы с готовыми решениями:

“Крестики-нолики”
Напишите игру “Крестики-нолики”. Программа выводит игровое поле для двух игроков, проверяет правильность ходов, следит за ситуацией на...

Крестики нолики
Помогите зделать защитить клетку от перезаписи другим игроком и написать функцию Check(), которая проверяет выиграшные комбинации, и...

Крестики-нолики
Ребят! Как сделать проверку на занятость квадратика? #include &lt;iostream&gt; using namespace std; int BoardSquare(int array) ...

4
 Аватар для amfisat
70 / 70 / 36
Регистрация: 16.06.2009
Сообщений: 240
27.04.2012, 13:47
C++ по умолчанию не поддерживается множественного сравнения. Итого:
C++
1
2
3
4
5
6
7
8
9
10
11
12
void check(){
 
    if(board[6]==board[7] && board[6]==board[8]){cout<<"Победили "<<board[6]<<" .";}
    else if(board[3]==board[4] && board[3]==board[5]) {cout<<"Победили "<<board[3]<<" .";}
     else if(board[0]==board[1] && board[0]==board[2]) {cout<<"Победили "<<board[0]<<" .";}
     else if(board[6]==board[3] && board[6]==board[0]) {cout<<"Победили "<<board[6]<<" .";}
     else if(board[7]==board[4] && board[7]==board[1]) {cout<<"Победили "<<board[7]<<" .";}
     else if(board[8]==board[5] && board[8]==board[2]) {cout<<"Победили "<<board[8]<<" .";}
     else if(board[6]==board[4] && board[6]==board[2]) {cout<<"Победили "<<board[6]<<" .";}
     else if(board[8]==board[4] && board[8]==board[0]) {cout<<"Победили "<<board[8]<<" .";}
     else cout <<"Ничья."<<endl; 
}
1
Sectronik
05.06.2012, 10:57
Здравствуйте! Я ещё начинающий. Решил написать игру крестики нолики.
У меня тоже выдаёт ничью, сделав два хода.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
/*Программа крестики-нолики.
Массив, в котором хранятся значения клеток, выводится на экран в виде матрицы 3*3.
Пользователь вводит номер клетки в которую он хочет поставить крестик.
Компьютер ставит нолик в случайную клетку.*/
#include<conio.h>
#include<iostream>
#include<stdlib.h>
#include<clocale>
using namespace std;
int i,j,r,n,p,k;
char x0_pole[9];
void main ()
{
    setlocale(LC_CTYPE,"Russian");
    k=0;
    for (n=0;n<3;n++)//Заполнение массива пробелами
    {x0_pole[i]=' ';}
    while(1)
    {
        system ("cls");//Очистка экрана
        for (i=0;i<3;i++)//Вывод массива на экран в виде матрицы
        {
            for (j=0;j<3;j++)
            {
                cout<<x0_pole[k];
                k++;
            }
            cout<<"\n";
        }
        cin>>p;//Ввод пользователя
        x0_pole[p]='X';//Присвоение элементу массива значения Х
        k=0;
        system ("cls");//Очистка экрана
        for (i=0;i<3;i++)//Вывод массива на экран в виде матрицы
        {
            for (j=0;j<3;j++)
            {
                cout<<x0_pole[k];
                k++;
            }
            cout<<"\n";
        }//Проверка занятости всех клеток "ничьи"
        if ((x0_pole[0]!=' ')&&(x0_pole[1]!=' ')&&(x0_pole[2]!=' ')&&(x0_pole[3]!=' ')&&(x0_pole[4]!=' ')&&(x0_pole[5]!=' ')&&(x0_pole[6]!=' ')&&(x0_pole[7]!=' ')&&(x0_pole[8]!=' '))
        {
            cout<<"Ничья";
            _getch();
            exit(0);
        }//Проверка выигрыша игрока
        else if ((x0_pole[0]=='X')&&(x0_pole[1]=='X')&&(x0_pole[2]=='X')||
                (x0_pole[3]=='X')&&(x0_pole[4]=='X')&&(x0_pole[5]=='X')||
                (x0_pole[6]=='X')&&(x0_pole[7]=='X')&&(x0_pole[8]=='X')||
                (x0_pole[0]=='X')&&(x0_pole[3]=='X')&&(x0_pole[6]=='X')||
                (x0_pole[1]=='X')&&(x0_pole[4]=='X')&&(x0_pole[7]=='X')||
                (x0_pole[2]=='X')&&(x0_pole[5]=='X')&&(x0_pole[8]=='X')||
                (x0_pole[0]=='X')&&(x0_pole[4]=='X')&&(x0_pole[8]=='X')||
                (x0_pole[2]=='X')&&(x0_pole[4]=='X')&&(x0_pole[6]=='X'))
        {
            cout<<"Вы выиграли";
            _getch();
            exit(0);
        }
        r=rand()%8;
        while (x0_pole[r]!=' ')
        {r=rand()%8;}
        x0_pole[r]='O';
        k=0;
        system ("cls");//Очистка экрана
        for (i=0;i<3;i++)//Вывод массива на экран в виде матрицы
        {
            for (j=0;j<3;j++)
            {
                cout<<x0_pole[k];
                k++;
            }
            cout<<"\n";
        }//Проверка занятости всех клеток "ничьи"
        if ((x0_pole[0]!=' ')&&(x0_pole[1]!=' ')&&(x0_pole[2]!=' ')&&(x0_pole[3]!=' ')&&(x0_pole[4]!=' ')&&(x0_pole[5]!=' ')&&(x0_pole[6]!=' ')&&(x0_pole[7]!=' ')&&(x0_pole[8]!=' '))
        {
            cout<<"Ничья";
            _getch();
            exit(0);
        }//Проверка выигрыша компьютера
        else if ((x0_pole[0]=='O')&&(x0_pole[1]=='O')&&(x0_pole[2]=='O')||
                (x0_pole[3]=='O')&&(x0_pole[4]=='O')&&(x0_pole[5]=='O')||
                (x0_pole[6]=='O')&&(x0_pole[7]=='O')&&(x0_pole[8]=='O')||
                (x0_pole[0]=='O')&&(x0_pole[3]=='O')&&(x0_pole[6]=='O')||
                (x0_pole[1]=='O')&&(x0_pole[4]=='O')&&(x0_pole[7]=='O')||
                (x0_pole[2]=='O')&&(x0_pole[5]=='O')&&(x0_pole[8]=='O')||
                (x0_pole[0]=='O')&&(x0_pole[4]=='O')&&(x0_pole[8]=='O')||
                (x0_pole[2]=='O')&&(x0_pole[4]=='O')&&(x0_pole[6]=='O'))
        {
            cout<<"Вы проиграли";
            _getch();
            exit(0);
        }
    }
}
Возможно мой код выглядит ужасно, но это единственное, что я смог придумать.
 Аватар для Alt_Shift
51 / 51 / 20
Регистрация: 28.05.2012
Сообщений: 161
05.06.2012, 11:05
действительно выглядит не очень. Не лучше ли сделать массив с выигрышными комбинациями и сравниваться в нем?
0
Sectronik
05.06.2012, 11:24
Можете предложить свой вариант?
А то я слабо представляю себе массив с выигрышными комбинациями.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
05.06.2012, 11:24
Помогаю со студенческими работами здесь

Крестики Нолики
Прошу помочь, я написал игру крестики нолики, но при вводе. Выводится только крестик. ПОмогите. Не знаю в чем ошибка. #include...

Крестики-нолики
Захотелось написать игру Крестики-нолики но тут возник один вопрос, как будет ходить компютер, если пользоватся rand-ом то компютер будет...

Крестики нолики на С
Здраствуйте. Помогите пожалуйста написать игру в консоли. Это крестики нолики поле 3х3. Буду благодарен если поможете и объясните. ...

Крестики-нолики
Всем привет. Учусь программировать с нуля, пока могу делать только что-нибудь простое. Хочу начать продвигаться вперёд, сейчас попробовал...

Крестики нолики
Доброго времени суток, недавно, я решил написать программу Крестики нолики, опираясь на свои знания в С++, но при компиляции кода...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru