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

шахматы - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Текстовый файл http://www.cyberforum.ru/cpp-beginners/thread127146.html
Разработайте программу, форматирующую текстовый файл в два столб- ца, аналогично газетным колонкам. В каждом столбце должно быть не более n слов, где n — параметр ком. строки. ________________ на С
C++ Определить, сколько раз встречается в файле введенное пользователем слово Дан текстовый файл. Напишите программу, которая определяет, сколько раз встречается в файле введенное пользователем слово. файл: C:\file.txt http://www.cyberforum.ru/cpp-beginners/thread127136.html
C++ Количество элементов парит
В одномерном массиве из n вещественных элементов как определить количество 0 в этом массиве?
как мне обойти все подкаталоги данного каталога.? C++
помогите плз разобраться с директориями. вот как мне обойти все подкаталоги данного каталога.?
C++ Из Pascal в С++ http://www.cyberforum.ru/cpp-beginners/thread127085.html
Дана действительная матрица размером n*m. Упорядочить (переставить) за спадением значений первых элементов столбцов program zada4a333; uses crt; const nmax=20; var a:array of real; m,n,i,j,k:byte; d:real; begin clrscr; repeat
C++ Поиск пути, волновой алгоритм Подскажите плз. как переделать программу чтобы в ней кроме преград, также были точки "телепортации". #include<conio.h> #include<stdio.h> #include<stdlib.h> struct screen_point{ // unsigned char chr; // unsigned char attr; // Это все нужно для вывода }; // на экpан. подробнее

Показать сообщение отдельно
Mr.X
Эксперт С++
 Аватар для Mr.X
3011 / 1667 / 265
Регистрация: 03.05.2010
Сообщений: 3,867
09.05.2010, 23:18     шахматы
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
//Разработать класс для моделирования шахматной фигуры, позволяющий 
//хранить вместе с экземпляром объекта его координаты на доске,
//цвет фигуры и число сделанных ей ходов. Встроенная функция “ход”
//должна получать новые координаты в виде параметров и изменять по-
//ложение фигуры на доске. Ходы, недопустимые для данной фигуры, не
//должны изменять ее координаты. Дана фигура: слон.
#include <iostream>
#include <string>
 
class chess_bishop;
std::ostream& operator<<(std::ostream& os, const chess_bishop& chb);
 
class chess_bishop
{   
public:
    chess_bishop(bool is_white, bool is_left) : _is_white(is_white), 
                                                _is_left(is_left), 
                                                _move_count(0)
    {
        if(_is_white)
        {
            _vert_coord  = '1';
            _horiz_coord = _is_left ? 'c' : 'f';
        }
        else
        {
            _vert_coord = '8';
            _horiz_coord = _is_left ? 'f' : 'c';
        }
        std::cout << "Create "
                  << *this
                  << std::endl;
    }
    
    void move(std::string coord)
    {
        std::string old_coord = get_coord();
        char horiz_coord  = coord[0];
        char vert_coord   = coord[1];
        bool correct_horiz_coord  = 'a' <= horiz_coord  &&  horiz_coord <= 'h';
        bool correct_vert_coord   = '1' <= vert_coord   &&  vert_coord  <= '8';
        bool correct_move 
            = correct_horiz_coord
              && correct_vert_coord
              && abs(horiz_coord - _horiz_coord) == abs(vert_coord - _vert_coord);
        if(correct_move)
        {
            _horiz_coord  = horiz_coord;
            _vert_coord   = vert_coord;
            ++_move_count;
            std::cout << *this
                      << "MOVE from "
                      << old_coord
                      << std::endl;
        }
        else
        {
            std::cout << *this                
                      << "NOT move to "
                      << coord                      
                      << std::endl;        
        }
    }
 
    std::string get_name() const
    {
        return std::string("chess_bishop ")
               + (_is_white ? "is_white " : "is_black ")
               + (_is_left ? "is_left " : "is_right ");
    }
 
    std::string get_coord() const
    {
        std::string res;
        res += _horiz_coord;
        return res += _vert_coord;        
    }
 
    size_t get_moves_count() const
    {
        return _move_count;
    }
private://Данные.
    bool    _is_white;
    bool    _is_left;
    size_t  _move_count;    
    char    _vert_coord;  //Изменяется от '1' до '8'.
    char    _horiz_coord; //Изменяется от 'a' до 'h'.   
};
 
std::ostream& operator<<(std::ostream& os, const chess_bishop& chb)
{
    os << chb.get_name()
       << chb.get_coord()
       << " ("
       << chb.get_moves_count()       
       << " moves) ";
    return os;
}
 
int main()
{
    //Тестирование класса.
    chess_bishop c(true, true);
    c.move("z9");
    c.move("d2");
    c.move("h5");
    c.move("h6");
    c.move("i7");
    c.move("f8");
    chess_bishop cwr(true, false);
    cwr.move("h3");
    cwr.move("i4");
    cwr.move("c3");
    cwr.move("c8");
    cwr.move("b9");
    chess_bishop cbl(false, true);
    cbl.move("a3");
    cbl.move("13");
    chess_bishop cbr(false, false);
    cbr.move("c1");
    cbr.move("a6");
    cbr.move("b5");
    return 0;
}
 
Текущее время: 02:12. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru