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

ООП - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Односвязные списки c++ http://www.cyberforum.ru/cpp-beginners/thread147907.html
Надо написать функцию, которая вставляет в список элемент со значением n после первого элемента со значением m. Реализовать как односвязный список(используя динамические структуры). Должны быть...
C++ Работа с текстовыми файлами Создать программу, которая обрабатывает файл в последовательном режиме. Данные надо считывать по одному символу (нельзя считывать сразу весь файл или строку) Дан не пустой текстовый файл.... http://www.cyberforum.ru/cpp-beginners/thread147901.html
строки и множества в С C++
Вывести в обратном порядке третье слово
C++ Матрицы в С++
Здравствуйте, форумчане...я, уповая на ваше помощь, прошу помочь мне с программой... Смысл задачи: Дана символьная матрица. Характеристикой строки назовем длину строки. Определить номер строки,...
C++ вывести элементы массива целых чисел http://www.cyberforum.ru/cpp-beginners/thread147887.html
вывести элементы массива целых чисел, которые находится между max и min
C++ Функция которая сравнивает два целых числа и возвращает результат сравнения в виде знака: >, < или = Используя функцию, которая сравнивает два целых числа и возвращает результат сравнения в виде знака: >, < или =, вычислить количество равных среди введенных трех чисел x, у, t. подробнее

Показать сообщение отдельно
_Eldar_
44 / 29 / 3
Регистрация: 31.10.2009
Сообщений: 200
22.06.2010, 09:17  [ТС]
AnTro.Net, там я косяк нашел) шаги считаются даже если вводишь неверную координату:
переписал немного:
файл Pyatn.h
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
#include "Pyatn.h"
#include <iostream>
#include <iomanip>
#include <algorithm>
#include <conio.h>
#include <windows.h>
 
using namespace std;
 
Space::Space(){
    for(int i = 0; i < 16; ++i)
        if (i < 15) arr.push_back(i + 1);
        else arr.push_back(-1);
 
    random_shuffle(arr.begin(), arr.end() - 1);
        
    num_X = 15;
    step = 1;
}
 
void Space::Show(){ 
    system("cls");
    cout << "======================================" << endl;
    cout << "Шаг " << step << endl << endl;
    int count = 0;
    cout << setw(6) << '|'
         << setw(3) << 'A' << " |"
         << setw(3) << 'B' << " |"
         << setw(3) << 'C' << " |"
         << setw(3) << 'D' << " |" << endl;
    cout << "--------------------------" << endl;
    for(vector<int>::iterator i = arr.begin(); i != arr.end(); ++i){
 
        
        if(! (count % 4)) cout << setw(3) << count / 4 + 1 << ". |";
        ++count;
        if(count % 4){
            if (*i == -1) cout << setw(3) << 'X' << " |";
            else cout << setw(3) << *i << " |";
 
        }
        else {
            if (*i == -1) cout << setw(3) << 'X' << " |";
            else cout << setw(3) << *i << " |";
            cout << endl;
            cout << "--------------------------" << endl;
        }
    }
    cout << endl;
         
}
 
void Space::Move(){
 
    string u_letter("ABCD");
    string l_letter("abcd");
    unsigned char row_cin;
    int row, col, value;
    int num_field;
    bool success = false;
    
    while(!success ){
        cout << "Введите координаты перемещаемой клетки: ";
        cin >> setw(3) >> row_cin;
        col = u_letter.find(row_cin);
        if(col == -1) col = l_letter.find(row_cin);
        if(col == -1) {
            cout << "Ошибка, повторите ввод" << endl;
            continue;
        }
        while(true){
            cin >> row;
            if(cin.peek() == '\n' && row <= 4){cin.get(); break;}
            else{
                cout << "Повторите ввод строки (ожидается целое число <= 4)" << endl;
                cin.clear();
                while(cin.get() != '\n'){};
            }
 
        }
        success = true;
    }
 
    num_field = col + (row - 1) * 4;
 
    if (Validate_num(num_field)){
        int temp = arr[num_field];
        arr[num_field] = arr[num_X];
        arr[num_X] = temp;
        num_X = num_field;
        ++step;
    }
}
 
bool Space::Validate_num(int num_field){
    
 
    try{
        arr.at(num_field);
    }
    catch(out_of_range){
        cout << "Ошибка, повторите ввод" << endl;
        return false;
    }
    
    vector<int> round_elem;
    try{
        round_elem.push_back(arr.at(num_X - 1));
    } catch(out_of_range){};
    try{
        round_elem.push_back(arr.at(num_X + 1));
    } catch(out_of_range){};
    try{
        round_elem.push_back(arr.at(num_X - 4));
    } catch(out_of_range){};
    try{
        round_elem.push_back(arr.at(num_X + 4));
    } catch(out_of_range){};
 
    for(vector<int>::iterator i = round_elem.begin(); i != round_elem.end(); ++i){
        if(*i == arr.at(num_field)) 
            return true;    
    }
    cout << "Невозможно переместить клетку" << endl;
    Sleep(1000);
    return false;
 
}
bool Space::Validate_End(){
    
    vector<int> sort_arr(arr);
    vector<int>::iterator i, j ;
    sort(sort_arr.begin(), sort_arr.end());
 
    cout << endl;
    for(i = arr.begin(), j = sort_arr.begin(); i != arr.end() - 1; ++i, ++j){
        if(*i == -1) ++i;
        if(*j == -1 ) ++j;
        if(*i != *j) return false;
    }
    cout << "Победа на " << step << " шаге !!!" << endl;
    return true;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru