Форум программистов, компьютерный форум CyberForum.ru

Не хочет работать программа(крестики-нолики). - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Контейнера http://www.cyberforum.ru/cpp-beginners/thread574200.html
Очень нужна ваша помощь помогите сделать это Необходимо: 1.заполнить случайными числами от 1 до 9 значения контейнеров vector и map 2.удалить случайное число элементов (не более 15) в каждом контейнере 3.после этого провести синхронизацию, чтобы в vector и map остались только имеющиеся в обоих контейнерах элементы (дубликаты не удалять).
C++ Найти сумму ряда Найти сумму ряда с точностью до члена ряда, меньшего 0.0001 для заданного значения и сравнить эту сумму с функцией контроля. Для вычисления последующего значения члена ряда использовать рекуррентную формулу. y=1+x^2/2!+...+(x^2*n)/(2*n)!-разложение функции в ряд x=0.5-значение y=(e^x+e^-x)/2-функция контроля http://www.cyberforum.ru/cpp-beginners/thread574198.html
C++ Включена ли в версию Visual C++ 2008 библиотека MFC?
Друзья подскажите такую вещь....Нашёл нашёл неплохую книгу Айвора Хортона Visual C ++ 2005 базовый курс.Он предлагает для практического изучения пару приложеней Visual studio 2005 (Standart,Professiona,Team System) и пишет ,что: " Visual С++ Express 2005 не пойдёт , поскольку в эту версию не включена библиотека MFC " . По иронии судьбы у меня оказалась как раз Visual С++ Express , но не 2005...
C++ Динамическое выделение памяти
Дана последовательность символов латинского алфавита, количество которых заранее не определено. Считать концом последовательности символ пробела. Вывести на печать гласные буквы из данной последовательности.
C++ Итератор для собственного контейнера http://www.cyberforum.ru/cpp-beginners/thread574183.html
понимаю, что уже создан миллион подобных тем, НО я не вьехал в них. мне необходимо реализовать собственный контейнер для использования его в алгоритмах stl контейнер организовал, теперь необходимо реализовать итератор, совместимый с STL-алгоритмами, тут и вышла заминка помогите кто чем может, пожалуйста!#include "stdafx.h" #include <iostream> #include <Windows.h> #include <map> #include...
C++ Динамические структуры данных 1.Разработайте динамическую структуру для решения задачи. Последовательность чисел Фибоначчи задается по закономерности: f1 = 1, f2 = 1, ..., fn = fn-1 + fn-2. Распечатайте n чисел Фибоначчи в следующем порядке: сначала все четные, затем все нечетные элементы. 2. Разработайте динамическую структуру для решения задачи. Даны целые числа p и q. Получить все делители числа q, взаимно простые с... подробнее

Показать сообщение отдельно
Dmitriy1342
1 / 1 / 0
Регистрация: 07.02.2012
Сообщений: 37

Не хочет работать программа(крестики-нолики). - C++

14.05.2012, 17:06. Просмотров 298. Ответов 0
Метки (Все метки)

Всем привет. Собственно не работает программа, ошибки не выдает, прошу помочь разобраться.
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
#include <iostream>
#include <conio.h>
using namespace std;
 
char board[9];
 
void clearboard(){
    for (int i=0; i<9; i++){
        board[i] ='-';
 
    }
}
 
bool has_wonQ(char player){
    int wins[][3]= {{0,1,2}, {3,4,5}, {6,7,8}, {6,3,0}, {7,4,1}, 
                    {8,5,2}, {0,4,8}, {6,4,2}};
 
    for (int i=0; i<8; i++){
        int count = 0;
        for (int j=0; j<3; j++){
            if(board[wins[i][j]] == player) 
                count++;
        }
        if (count==3){
            return true;
        }
    }
    
    return false;
}
 
 
void print_board(){
    
    cout <<"-"<<board[6]<<"-|-"<<board[7]<<"-|-"<<board[8]<<"-"<<"\n";
    cout <<"-"<<board[3]<<"-|-"<<board[4]<<"-|-"<<board[5]<<"-"<<"\n";
    cout <<"-"<<board[0]<<"-|-"<<board[1]<<"-|-"<<board[2]<<"-"<<"\n";
 
}
 
int get_move(){
 
    cout <<"\nПодсказка\n";
    cout <<"-7-|-8-|-9-"<<endl;
    cout <<"-4-|-5-|-6-"<<endl;
    cout <<"-1-|-2-|-3-"<<endl;
    cout <<"\n";
 
    cout <<"Игровое поле: \n";
    print_board();
    cout <<"\nВаш ход:";
 
    int move;
    cin>>move;
    
    while(move>9 || move<1 || board[move-1] !='-'){
        cout <<"Пожалуйста, сделайте правильный ход:\n";
        cin>>move;
    }
    return move;
 
}
 
char play_and_get_winner(){
    int turn = 1;
 
    while(!has_wonQ('X') && !has_wonQ('O')){
        system("cls");
        int move = get_move();
        //cout <<"Ваш ход был: "<<move<<endl;
        if(turn%2==1) { 
            board[move-1]='X';
                if(has_wonQ('X')){
                    cout <<"Победили крестики, поздравляем!\n";
                return 'X';
        }
    }
    else { 
        board[move-1]='O';
        if(has_wonQ('O')){
            cout <<"Победили нолики, поздравляем!\n";
            return 'O';
        }
    }
    turn++;
    if(turn == 10){
        cout <<"Ничья!\n";
        return 'D';
        }
    }
}
 
int main(){
    setlocale (LC_ALL, "Russian");
 
    cout <<"Приветствуем в игре Крестики-нолики!\n";
    char reply[] = "y";
    int x_wins=0, o_wins=0, ties=0;
    
    while (reply == "y"){
    clearboard();
    char winner = play_and_get_winner();
    print_board();
 
    switch(winner){
    case 'X':
        x_wins++;
        break;
    case 'O':
        o_wins++;
        break;
    case 'D':
        ties++;
        break;
    }
 
    cout <<"\nСтатистика побед\nИгрок Х: "<<x_wins
        <<", Игрок О: "<<o_wins<<"Ничья: "<<ties<<"\n\n";
    cout <<"\nХотите сыграть еще?(y/n):";
    cin >>reply;
    while(reply !="y" && reply !="n"){
        cout <<"Пожалуйста, введите правильный ответ:";
        cin >>reply;
    }
    }
 
    getch();
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru