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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.64
Leka_1
3 / 3 / 0
Регистрация: 30.07.2012
Сообщений: 57
#1

Судоку - C++

06.09.2012, 18:57. Просмотров 1518. Ответов 2
Метки нет (Все метки)

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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
# include <algorithm>
# include <iostream>
# include <string.h>
# include <stdio.h>
# include <iomanip>
# include <vector>
using namespace std;
class cell
{
int namber;
};
class Sudoku : public cell
{
int candidate;
int size;
int tabl [9][9];
int zn;
int zn1;
int namber;
public:
void Input()
{
cout << "Ведите номер строки ="<<" ";
cin >> zn;
cout << "\nВедите номер столбца =" <<" ";
cin >> zn1;
cout << "\nВедите значение ячейки ="<<" ";
cin >> namber;
}
Sudoku();
~Sudoku();
void Print();
void replace();
void DelAll();
};
Sudoku::Sudoku()
{
size = 0;
}
Sudoku::~Sudoku()
{
DelAll();
}
void Sudoku::DelAll()
{
int n;
}
void Sudoku ::replace()
{
const int row = 9;
const int col = 9;
std::vector<std::vector<int> > tabl(row);
// Заполнение
for(int i = 0; i < row; ++i)
{
tabl[i].resize(col);
for(int j = 0; j < col; ++j)
{
if (i != (zn-1))
{
//tabl[i][j] = 0;
cout<<setw(5)<<"___"<<" ";
}
if (i == (zn-1))
{
if (j != (zn1-1))
{
//tabl[i][j] = 0;
cout<<setw(5)<<"___"<<" ";
}
if (j == (zn1-1))
{
tabl[i][j] = namber;
cout<<setw(3)<<"["<<namber<<"]"<<setw(1)<<" ";
}
}
}
cout<<"\n\n";
 
}
}
гЂЂ
void Sudoku::Print()
{
}
void main() 
{ 
srand (time(NULL));
setlocale (LC_CTYPE, "rus");
Sudoku Decision [50];
int key;
int zn;
int zn1;
int namber;
int count=0;
int tabl[9][9];
/*for (int i=0; i<9; i++)
{
for (int j=0; j<9; ++j)
{
tabl[i][j]=rand()%1; 
}
cout<<"\n\n";
}
for (int i=0; i<9; i++)
{
for (int j=0; j<9; ++j)
{
cout<<tabl[i][j]<<" ";
}
cout<<"\n\n";
}*/
cout << "\n\n" << "\t\tИгра - С У Д О К У\n\n";
cout <<setw(5)<< "1" <<setw(5)<< "2" <<setw(5)<<"3"<<setw(8)<<"4"<<setw(5)<<"5"<<setw(5)<<"6"<<setw(8)<<"7"<<setw(5)<<"8"<<setw(5)<<"9"<<"\n";
cout << " 1 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n";
cout << " 2 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n";
cout << " 3 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n\n\n";
cout << " 4 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n";
cout << " 5 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n";
cout << " 6 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n\n\n";
cout << " 7 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n";
cout << " 8 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n";
cout << " 9 " << "___ ___ ___ ___ ___ ___ ___ ___ ___"<<"\n\n\n";
 
do
{
cout << "Ввод некоторых значений Судоку пользователем - 1"<<"\n";
cout << "Проверка ввода пользователем значений - 2" <<"\n";
cout << "Решение Судоку программой - 3" <<"\n";
cout << "Очистка решения программы - 4" <<"\n";
cout << "Печать на экран - 5" <<"\n";
cout << "Выход с игры - 6" <<"\n\n\n"; 
 
cout << "Сделайте свой выбор"<<"\t";
cin >> key;
cout << "\n";
switch (key)
{
case 1:
do
{
cout << "Введите кординаты ячеек которые хотите заполнить";
cout <<" "<< "Например 1 1\n";
cout <<"Ввод координат -1"<<endl;
cout <<"Назад - 2"<<endl;
cout << "Сделайте свой выбор"<<"\t";
cin >> key;
cout<< "\n";
switch (key)
{
case 1:
cout<<"Добавляем в Судоку\n";
Decision [count].Input();
count++;
break;
case 2:
continue;
default:
cout << "E R R O R" << "\n";
}
continue;
}
while (key!=2);
 
case 2:
break;
case 3:
break;
case 4:
break;
case 5:
if (count!=0)
{
for (int i=0; i<count; i++)
{
Decision[i].replace();
}
}
Decision[50].Print();
break;
case 6:
exit(0);
break;
default:
cout << "E R R O R" << "\n";
}
}
while (key!=6);
}
/*Суть проблемы заключается в том, что у меня при вводе пользователя вместо налаживания в таблицу значений, т.е. накопления, формируются отдельные таблицы, а без этого я не могу двинуться дальше пож. помогите*/
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
06.09.2012, 18:57
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Судоку (C++):

Судоку - C++
Добрый день! Очень нужна помощь! Нужен код СУДОКУ на С++, задали на курсовую, ничего не получается. В гугле искала, не нашла

Судоку си++ - C++
Подскажите пожалуйста как правильно создать таблицу 9*9 для ввода значений?

Судоку - C++
Помогите написать игру судоку. я программирую в С++. Мне дали задание написать игру судоку в консольке. Только без всяких наворотов,...

Судоку - C++
6. (6 и 7 лабораторная работа) – Судоку. (6 – заполнение массива).

Решение Судоку - C++
Здравствуйте! Заранее извеняюсь за повтор, писал такую тему в алгоритмах, но там глухо :( Интересует алгоритм для программы,...

почти судоку) - C++
Уже создавала эту тему, но никто не ответил.Может не увидели или не успели.. .Если кто может помочь прошу помогите решить задачу на СИ ...

2
Leka_1
3 / 3 / 0
Регистрация: 30.07.2012
Сообщений: 57
06.09.2012, 21:51  [ТС] #2
Вопрос заключается в следующем:
при игре судоку пользователь заполняет значения самостоятельно, т.е
__ __ __ 5 __ __ __
1 __ 4 __ __ __
и так далее таблица 9 х 9, у меня же получается при вводе пользователем только одна цифра. остальные в эту же таблицу не заносятся, а создаютя еще таблицы 9х9, тоже с одной цифрой
думала использовать iterator insert (iterator i, const T &val = T()); но не могу придумать как его использовать

а код отвечающий за этот "бардак"


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
void Sudoku ::replace()
{
    const int row = 9;
    const int col = 9;
    std::vector<std::vector<int> > tabl(row);
    // Заполнение
    for(int i = 0; i < row; ++i)
    {
        tabl[i].resize(col);
        for(int j = 0; j < col; ++j)
        {
 
            if (i != (zn-1))
                    {
                        cout<<setw(5)<<"___"<<" ";
                    }
                    if (i == (zn-1))
                    {
                        if (j != (zn1-1))
                        {
                            cout<<setw(5)<<"___"<<" ";
                        }
                        if (j == (zn1-1))
                        {
                        tabl[i][j] = namber;
                cout<<setw(3)<<"["<<namber<<"]"<<setw(1)<<" ";
                        }
                    }
        }
    cout<<"\n\n";
          
    }
}
Добавлено через 10 минут
Я понимаю, что поверх не существующих значений, должны налаживатся вводимые пользователем значения, но не могу придумать как это сделать, помогите пожайлуста!!!
0
cactus09
Чайник
69 / 69 / 4
Регистрация: 15.02.2012
Сообщений: 475
06.09.2012, 22:52 #3
Я б сделал так: массив int"ов 9 на 9 сначала заполняется все элементы какимнибудь числом более 9 (например 13 ) потом рандомно заполняется те элементы которые изначально имеют какое-либо значение можно например так
C++
1
2
3
4
5
6
...
srand(time(0));
for(int i=1;i<10;i++){
  mass[int(rand()%10)][int(rand()%10)]=i;
 }
...
А потом функция печати если увидить 13 напечатает " - ". А далее вод просто как присвоение переменной (конечно с проверкой допустимости значения) и кординат(чтоб не были задеты изначально занятые элементы)
2
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
06.09.2012, 22:52
Привет! Вот еще темы с ответами:

решение судоку - C++
Судоку размера n называется квадрат со стороной n2, разделенный на n2 средних квадратов со стороной n, каждый из которых разделен на n2...

проверка судоку - C++
Помогите пожалуйста написать программу , которая проверяет правильность решения судоку. Мне нужно ,чтобы в двумерном массиве в каждой...

Судоку (латинский квадрат) - C++
Помогите плиз с задачей на VS C++ 2010 Латинским квадратом размера n называется таблица n × n, заполненная n различными символами...

Разные соседи (Судоку) - C++
Разные соседи. Заполнить матрицу заданного размера M(k, l) числами 1,2,3,4 так, чтобы по горизонтали, вертикали и диагонали не было...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.