配列にオブジェクトがない場合でも、アドレスが残っていることを私は知っています。しかし、私たちが尋ねる特定のインデックスの下にオブジェクトがあるかどうかを確認するための解決策を見つけたいと思います。ポリゴンに新しいポイントを追加するには、このようなメカニズムが必要です。しかしその前に、オブジェクトがあった場合にオブジェクトのカウンターが大きくなるか、同じ値にとどまるかを知る必要があります。たぶん私はすべての配列をNULL
?
main.cpp
#include <iostream>
#include "punkt.h"
#include "wielokat.h"
using namespace std;
int main(int argc, char *argv[])
{
Punkt p1("p1", 10, 20); // 10x20
Punkt p2("p2", 1, 1); //1x1
Wielokat w1 ("square", 4);
w1.set(p1,0);
w1.set(p2,0);
w1.showWielokat();
system("PAUSE");
return EXIT_SUCCESS;
}
Wielokat.cpp
#include "punkt.h"
#include "wielokat.h"
#include <iostream>
using namespace std;
void Wielokat::increase(int n)
{
m_ilosc = m_ilosc + n;
m_tab = new Punkt * [m_ilosc];
cout<<"Dodaj "<<m_ilosc<<endl;
}
void Wielokat::decrease(int n)
{
m_ilosc = m_ilosc - n;
if(m_ilosc<0){ m_ilosc=0;}
m_tab = new Punkt * [m_ilosc];
cout<<"Odejmij "<<m_ilosc<<endl;
}
void Wielokat::set(Punkt p, int pos)
{
//How to check if there was already object ?
m_tab[pos] = new Punkt(p);
m_counter++;
}
void Wielokat::showWielokat()
{
for(int i=0; i<m_counter; i++){
m_tab[i]->show();
}
}
void Wielokat::crash(int pos){
//after delete all elements moved one by one to the left side
delete m_tab[pos];
for(int i=pos; i<m_ilosc; i++){
m_tab[i]=m_tab[pos+1];
}
}
double Wielokat::getParimeter(){
//here is function whih will count circuit
}
Wielokat.h
class Wielokat {
public:
Wielokat(char* nazwa, int ilosc):m_nazwa(nazwa), m_ilosc(ilosc)
{
m_tab = new Punkt * [m_ilosc];
m_counter = 0;
}
Wielokat(const Wielokat& p): m_ilosc(p.m_ilosc), m_nazwa(strdup(p.m_nazwa))
{}
~Wielokat()
{
for(int i=0; i<m_counter; i++){
delete m_tab[i];
}
delete m_tab;
}
//Function:
void increase(int n);
void decrease(int n);
void set(Punkt p, int pos);
void crash(int pos); //delete
void showWielokat();
double getParimeter();
private:
Punkt **m_tab; //our tab of elemenst
char* m_nazwa;
int m_ilosc;
int m_counter;
};