Portál AbcLinuxu, 13. července 2025 02:53


Dotaz: C++ problem s dynamickým polem řetězců

kozzi avatar 7.12.2006 17:50 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
C++ problem s dynamickým polem řetězců
Přečteno: 1181×
Odpovědět | Admin
Poslední dobou jsem začal psát nějakej kód v C++ a narazil jsem na drobný problém. Mám pole které je vytvořeno příkazem new vapadá to nejak takto: string *promena = new string[count]; no a potreboval bych nejak zařídit aby se mi vytvořené pole zvětšilo o jedna takže bude mít velikost count + 1, jde mi o to že mám dvě taková pole a jedno má velikost count a druhé count + 1, a já potřebuju aby se do toho jednoho(menčího) načetlo to první.
Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

7.12.2006 17:57 trekker.dk
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
Odpovědět | | Sbalit | Link | Blokovat | Admin
Zkus použít typ vector<string> ze standardní knihovny. Ten udělá práci za tebe.
kozzi avatar 7.12.2006 18:05 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
díky, možná o tomo popřemýšlím, ale raději bych si to napsal sám, jde tu o to, že to nepoužívám jen ze stringem ale vytvářím pole i s jinýma typama napříkald z různýma strukturama, takže by se mi hodilo něco jinýho. Já to řeším nejak takto ale zdá se mi to neefektivní.

...
string *tmp;
        tmp = new string[count + 1];
        if(count > 0)
        {
                for(int k = 0; k < count; k++)
                {
                        tmp[k] =  retezec[k];
                }
                delete [] retezec;
        }



        tmp[count] = item;
        retezec = tmp;

        //struktura[count] = item;
        count+=1;
...
Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
7.12.2006 18:09 Michal Kubeček | skóre: 72 | Luštěnice
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
Tím spíš je vhodnější použít std::vector (nebo jiný kontejner podle toho, jaké to má mít vlastnosti).
7.12.2006 19:19 Sinuhet | skóre: 31
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
std::vector<TYPE> vec;
TYPE item;

vec.push_back(item);
kozzi avatar 7.12.2006 19:29 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
díky, to mi moc pomohlo.
Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
7.12.2006 19:39 Sinuhet | skóre: 31
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců

Nemate zac.

Kdybyste radsi poradne napsal co chcete delat, abychom se konecne dozvedeli proc nemuzete pouzit vector. A pripadne vam poradili neco jineho.

kozzi avatar 7.12.2006 19:43 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
No ja vam dekuju za to ze jste mi ukazal ze jde vector pouzit i jinak nez sem myslel, takze ho muzu pouzit a tudiz je muj problem vyresen, doufam. Zkusim to az zitra. Dam vedet, ale myslim si ze by to melo byt OK.
Linux je jako mušketýři "jeden za všechny, všichni za jednoho"
7.12.2006 18:35 ivan | skóre: 17 | blog: ivan
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
Odpovědět | | Sbalit | Link | Blokovat | Admin
Zrovna prolistovavam knizku "C++ 101 programovacich technik" od Alexandrescu a tam se jedna kapitola jmenuje "Misto poli pouzivejte vector nebo string kdekoli je to mozne" :) Vector ma tu vyhodu, ze pri dealokaci nemusis premejslet jestli pouzit delete nebo delete[].
elviin avatar 7.12.2006 20:14 elviin | skóre: 29 | blog: elviin | Plzeň-Praha
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
Odpovědět | | Sbalit | Link | Blokovat | Admin
Mala motivace na pole, vektory:

#include <string> //std::string
#include <vector> //std::vector
#include <algorithm> //std::copy
#include <iostream> //std::cout
#include <iterator> //std::ostream_iterator

int main(int argc, const char* argv[])
{
    // nakopiruje pole do std::vector
    std::vector<std::string> vektor(argv, argv + argc);
    
    //vytiskne kazdy retezec a oddeli koncem radku
    std::copy(
	    vektor.begin(), 
	    vektor.end(), 
            std::ostream_iterator<std::string>(std::cout,"\n")
	);
}
kozzi avatar 8.12.2006 10:28 kozzi | skóre: 55 | blog: vse_o_vsem | Pacman (Bratrušov)
Rozbalit Rozbalit vše Re: C++ problem s dynamickým polem řetězců
Odpovědět | | Sbalit | Link | Blokovat | Admin
Takže všem mockrát díky, stím vectorem jste měli pravdu, je to perfektní věc. Dneska jsem to vyzkousel a jede to perfektně, je to rychlejší a zabírá to mín paměti než moje vlastní třídy. Jen mě mrzí, že jsem ještě chvíli nepočkal, protože se učím podle knížky mistrovství v C++ a asi 10 stránek za místem kam jsem došel, se vectorem ta knížka zabývá.
Linux je jako mušketýři "jeden za všechny, všichni za jednoho"

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.