Ayuda error en array bidimensional

Iniciado por kerkox, 21 Abril 2014, 02:58 AM

0 Miembros y 1 Visitante están viendo este tema.

kerkox

Hola amigos estoy tratando de hacer un tablero con un array bidimensional, pero me da un error cuando en la clase del tablero he definido que debe de contener un array de 3x3 y tambien lo he hecho con uno sin definir pero no funciona da error
el codigo es el siguiente

Este es el tablero.h

Código (cpp) [Seleccionar]
#include <iostream>
#include <stdlib.h>
#include "windows.h"
using namespace std;
#ifndef TABLERO_H
#define TABLERO_H




class tablero
{
    public:
        tablero(){}
        tablero(string tablelimpio);
        ~tablero();
        string dartablero();
     protected:
    private:
        string vacio;
        int i, j, k;
        string tavacio;

};

#endif // TABLERO_H


este es el tablero.cpp

Código (cpp) [Seleccionar]
#include "tablero.h"


tablero::tablero(string tablelimpio)
{

    tavacio=tablelimpio;
    //cto

}

tablero::~tablero()
{
    //dtor
}
string tablero::dartablero()
{
  return tavacio;
}


he hecho una espcie de menu en el cual se crea el objeto de tipo tablero pero es en este en el que ocurre el error

este es la clase Menu.h

Código (cpp) [Seleccionar]
#include "tablero.h"
#ifndef MENU_H
#define MENU_H
using namespace std;

class Menu
{
    public:
        Menu();
        ~Menu();
       void vertablero();
       void evaluarTipojuego();
    protected:
    private:
        tablero t1;
        int tipojuego;
        string vacio;
};

#endif // MENU_H



este es le Menu.cpp

Código (cpp) [Seleccionar]
#include "Menu.h"

Menu::Menu()
{

    tablero t( vacio={"-","-","-","-","-","-","-","-","-"});
    t1=t;

    //ctor
}

Menu::~Menu()
{
    //dtor
}

void Menu::vertablero()
{
cout << "esto es un juego de triki" << endl;
    cout << "" << endl;
    cout << "__________________________" << endl;
    cout << "" << endl;



    for (int i=0; i <3; i++)
        {
            cout << "|"  << t1.dartablero()[i][0] << "|" << "\t";
        }
    cout << endl;

    for (int j=0; j<3;j++)
        {
            cout << "|" << t1.dartablero()[j][1] << "|" << "\t";
        }
    cout << endl;

    for(int k=0; k<3; k++)
        {
            cout << "|" << t1.dartablero()[k][2]<< "|" <<"\t" ;
        }
    cout << endl;
}

void Menu::evaluarTipojuego()
{

}


y este es el main

Código (cpp) [Seleccionar]
#include "Menu.h"


using namespace std;

int main()
{

  cout << "Este es el juego de triki  " << endl;
  cin.get();
Menu triki;
triki.vertablero();
   system("pause");

}


si alguien me puede ayudar ya que buscado informacion en internet pero no he podido dar con el problema claramente.

Por otro lado tambien encontre que puedo usar vector en vez de array para hacer la matriz

eferion

La forma correcta que debería tener un archivo de cabecera es:

Código (cpp) [Seleccionar]

#ifndef TABLERO_H
#define TABLERO_H

#include <iostream>
#include <stdlib.h>
#include <windows.h>

using namespace std;

class tablero
{
    public:
        tablero(){}
        tablero(string tablelimpio);
        ~tablero();
        string dartablero();
     protected:
    private:
        string vacio;
        int i, j, k;
        string tavacio;

};

#endif // TABLERO_H


O en su defecto

Código (cpp) [Seleccionar]

#pragma once

#include <iostream>
#include <stdlib.h>
#include <windows.h>

using namespace std;

class tablero
{
    public:
        tablero(){}
        tablero(string tablelimpio);
        ~tablero();
        string dartablero();
     protected:
    private:
        string vacio;
        int i, j, k;
        string tavacio;

};


La protección ifndef debería abarcar todo el fichero, ya que así evitas que en el proceso de compilación y linkado y se carguen los includes de ese fichero varias veces seguidas.

Además, en el caso de esta clase, no usas las variables i,j,k y vacio... deberías eliminarlas.

Código (cpp) [Seleccionar]

    tablero t( vacio={"-","-","-","-","-","-","-","-","-"});


¿¿¿??? qué sentido tiene "vacio" en este contexto?? si quieres definir el "tablero" de esta forma, perfecto, pero no emplees un miembro de "menu" específicamente para eso... usa mejor variables locales:

Código (cpp) [Seleccionar]

Menu::Menu()
{
    string strTablero = {"-","-","-","-","-","-","-","-","-"};
    t1 = tablero( strTablero );
    //ctor
}


O mejor aún:

Código (cpp) [Seleccionar]

Menu::Menu( )
  : t1( "---------" )
{
    //ctor
}


Recuerda que con cada pareja de comillas estás definiendo una cadena, no un carácter suelto ( y las cadenas terminan todas con '\0', mientras que un carácter es... solo un carácter ).

En los ejemplos que has puesto tu, primero se llama al constructor de t1, después se crea t y después se hace una asignación... en este último caso únicamente se llama al constructor de t1. Es más bonito y eficiente.

Código (cpp) [Seleccionar]

            cout << "|"  << t1.dartablero()[i][0] << "|" << "\t";


A ver, si dartablero( ) devuelve un string, no puedes usarlo como si fuese una matriz... porque no lo es... en tal caso podrías usarlo como un vector, pero poco más. Puedes emular una matriz con un vector... pero recuerda que es una emulación, en ningún caso sería una matriz real:

Código (cpp) [Seleccionar]

    for (int i=0; i <3; i++)
        {
            cout << "|"  << t1.dartablero()[i * filasPorColumna] << "|" << "\t";
        }
    cout << endl;

    for (int j=0; j<3;j++)
        {
            cout << "|" << t1.dartablero()[j * filasPorCoumna + 1] << "|" << "\t";
        }
    cout << endl;

    for(int k=0; k<3; k++)
        {
            cout << "|" << t1.dartablero()[k * filasPorColumna + 2]<< "|" <<"\t" ;
        }


Y por cierto, podrías reutilizar i en cada bucle... no vas a tener ningún problema:

Código (cpp) [Seleccionar]

    for (int i=0; i <3; i++)
        {
            cout << "|"  << t1.dartablero()[i * filasPorColumna] << "|" << "\t";
        }
    cout << endl;

    for (int i=0; i <3; i++)
        {
            cout << "|" << t1.dartablero()[i * filasPorCoumna + 1] << "|" << "\t";
        }
    cout << endl;

    for (int i=0; i <3; i++)
        {
            cout << "|" << t1.dartablero()[i * filasPorColumna + 2]<< "|" <<"\t" ;
        }


O, ya puestos, combinarlos, que no tiene sentido tanto bucle:

Código (cpp) [Seleccionar]

for (int fila=0; fila <3; fila++)
{
  for ( int col = 0; col < 3; col++ )
    cout << "|"  << t1.dartablero()[ fila * filasPorColumna + col ] << "|" << "\t";
  cout << endl;
}


el valor de filasPorColumna, en tu caso, debería valer 3, por si acaso dudas.

En cualquier caso, lo suyo es que usases una matriz de tipo char y así te evitas tener que emular el comportamiento de una matriz... la clase string no es la mejor opción en tu caso.