Так что это моя программа на данный момент:
#include <iostream>
#include <windows.h>
using namespace std;
int colonne;
int ligne;
void initDamier (int damier[ligne][colonne])
{
for (int i = 0; i < ligne; ++i)
for (int j = 0; i < colonne; ++j)
damier[i][j]=0; //0=case vide
}
void afficheDamier (int damier[ligne][colonne])
{
for (int i = 0; i < ligne; ++i)
{
cout<<endl;
for (int j = 0; j < colonne; ++j)
{
cout<<damier[i][j]<<"|";
}
}
}
int main()
{
int a,b;
cout<<"Entrez le nombre de ligne du damier:"<<endl;
cin>>a;
ligne=a;
cout<<"Entrez le nombre de colonne du damier:"<<endl;
cin>>b;
colonne=b;
int damier[ligne][colonne];
initDamier(damier);
afficheDamier(damier);
return 0;
}
Я понимаю, почему это не работает. В damier[*][*]
, *
должен быть либо const
или фиксированный номер. Может кто-нибудь сказать мне, как обойти это?
Вы говорите о динамическом распределении памяти. Как Тоби303 говорит, в C ++ вы, вероятно, захотите использовать vector
справиться с этим.
Таким образом, весь первый раздел вашего кода может быть заменен на:
size_t a, b;
cout << "Entrez le nombre de ligne du damier:" << endl;
cin >> a;
cout << "Entrez le nombre de colonne du damier:" << endl;
cin >> b;
vector<vector<int>> damier(a, vector<int>(b, 0));
afficheDamier(damier);
Для того, чтобы работать с vector
вам также нужно изменить afficheDamier
:
void afficheDamier(vector<vector<int>> damier) {
for(auto& i : damier){
cout << endl;
for(auto& j : i) {
cout << j << '|';
}
}
}
Пожалуйста, обратите внимание: я предложил vector<vector<int>>
здесь, что, вероятно, является самым простым подходом к тому, чтобы заставить пример игрушки работать, но в рабочем коде, избегая vector
из vector
s было бы желательно: Каковы проблемы с вектором векторов?
Слушайте предложение tobi303: используйте std::vector
#include <vector>
#include <iostream>
void afficheDamier (std::vector<std::vector<int> > const & damier)
{
std::vector<std::vector<int> >::const_iterator cil;
std::vector<int>::const_iterator cic;
for ( cil = damier.begin() ; cil != damier.end() ; ++cil )
{
std::cout << std::endl;
for ( cic = cil->begin() ; cic != cil->end() ; ++cic )
std::cout << (*cic) << '|';
}
std::cout << std::endl;
}
int main()
{
int ligne, colonne;
std::cout << "Entrez le nombre de ligne du damier:" << std::endl;
std::cin >> ligne;
std::cout << "Entrez le nombre de colonne du damier:" << std::endl;
std::cin >> colonne;
std::vector<std::vector<int> > damier(ligne, std::vector<int>(colonne, 0));
afficheDamier(damier);
return 0;
}
Если вы используете компилятор C ++ 11, afficheDamier()
можно пояснить следующим образом (как предложил Джонатан Ми)
void afficheDamier (std::vector<std::vector<int>> const & damier)
{
for ( auto const & l : damier )
{
std::cout << std::endl;
for ( auto const & c : l )
std::cout << c << '|';
}
std::cout << std::endl;
}
Если вы хотите использовать массивы, а не std::vector
Вы можете использовать шаблон функции, который принимает массив по ссылке:
template<size_t ligne, size_t colonne>
void initDamier (int (&damier)[ligne][colonne])
{
for (int i = 0; i < ligne; ++i)
for (int j = 0; j < colonne; ++j) // Note that you had a nasty typo in this line
damier[i][j]=0;
}
или даже
template<size_t ligne, size_t colonne>
void initDamier (int (&damier)[ligne][colonne])
{
for (auto& x: damier)
for (auto& y: x)
y = 0;
}
Может быть, другое решение будет:
#include <iostream>
using namespace std;
int colonne;
int ligne;
void initDamier (int **damier, int ligne, int colonne)
{
for (int i = 0; i < ligne; ++i){
for (int j = 0; j < colonne; ++j){
damier[i][j]=0; //0=case vide
}
}
}
—
void afficheDamier (int **damier, int ligne, int colonne)
{
for (int i = 0; i < ligne; ++i)
{
cout<<endl;
for (int j = 0; j < colonne; ++j)
{
cout<<damier[i][j]<<"|";
}
}
cout<<endl;
}
—
int main()
{
int a,b;
cout<<"Entrez le nombre de ligne du damier:"<<endl;
cin>>a;
ligne=a;
cout<<"Entrez le nombre de colonne du damier:"<<endl;
cin>>b;
colonne=b;
int** damier = new int*[colonne];
for(int i=0;i<colonne;i++)
damier[i] = new int[ligne];
initDamier(damier,ligne, colonne);
afficheDamier(damier, ligne, colonne);
for(int i=0;i<colonne;i++)
delete damier[i];
delete[] damier;
return 0;
}