- sziku69: Fűzzük össze a szavakat :)
- bambano: Bambanő háza tája
- eBay-es kütyük kis pénzért
- Luck Dragon: Alza kuponok – aktuális kedvezmények, tippek és tapasztalatok (külön igényre)
- Luck Dragon: Asszociációs játék. :)
- Elektromos rásegítésű kerékpárok
- plevips: Sorozatkövető v 1.1
- Candy: IGPU dGPU passthrough, avagy a nem minden arany, amin megy a Furmark
- sziku69: Szólánc.
- D@reeo: Pi-hole és a Telekom Sagemcom F@st 5670 DNS beállítása
-
LOGOUT

Új hozzászólás Aktív témák
-
joysefke
veterán
Úgy látom a topkiban a sprint demók és határidők nem e-hét csütörtök péntekre estek...
-
joysefke
veterán
válasz
dabadab
#11263
üzenetére
Közben megnéztem mi a
cin >> akármi;
getline(str);összeakadás oka, ha egymás után (ebben a sorrendben) olvasnak a bemenetről:
acinfigyelmen kívül hagyja az újsor karaktert és nem veszi el a bemenetről. Ha a getline(str) ezután olvas, akkor nem a következő sorból olvas, hanem az egy szem újsor karaktert fogyasztja el és leáll.J.
-
joysefke
veterán
1000 éve programoztam C++-ban (meg úgy egyébként) és most a C++ még nagyobb ocsmányságnak tűnik mint anno

Nyilván az én sutaságom a fő oka, de akkor is, nem egy barátságos valami... -
joysefke
veterán
válasz
dabadab
#11258
üzenetére
Ok, az alábbi kód tesztelve és, működik.
Két hiba volt:
(1)
első (ocsmány) hiba:
az első sort beolvasócin >> aN >> reads;
összeakad a második (és utána következő aN) sort beolvasó:getline(cin, line);
istringstream s(line);kóddal. A
getline(cin, string line)valamiért az első, acin >> aN >> reads
által olvasott sort is olvassa, pedig csak a másodiktól kellene olvasnia. Elimináltam ez egész kódból a cin-t, és mindent soronként olvasok és parsolok, így működik.(2)
A vector<vector<int>> struktúrát (nyilván) rosszul inicializáltam. Most deklaráltam két változót:vector<vector<int>> a;
vector<int> b;A
b-t inicializálom, feltöltöm és belea.push_back(b)aza-ba.Tudom, hogy ez favágó programozás, mert biztos vagyok benne, hogy az a.push_back(b) az egy felesleges (kikerülhető) másolás, illetve a
while (s >> temp) {
b.push_back(temp);
}kódrészlet sem optimális, mivel nem használom ki, hogy ismerem a b-vektor hosszát, ezért felesleges resize műveleteket fog csinálni a kód runtime-ban...
szerk: beleraktam egyb.reserve(temp)-et, ez feltételezem kiküszöböli a runtime resize-olást...int main() {
int aN = -1;
int reads = -1;
string line;
int temp;
int r, c;
getline(cin, line);
istringstream s(line);
s >> aN;
s >> reads;
vector<vector<int>> a;
vector<int> b;
for (int i = 0; i != aN; ++i) {
getline(cin, line);
istringstream s(line);
s >> temp;
b.clear();
while (s >> temp) {
b.push_back(temp);
}
a.push_back(b);
}
for (int i = 0; i != reads; ++i) {
cin >> r >> c;
cout << a[r][c] << endl;
}
return 0;
} -
joysefke
veterán
ez mind szép és jó, de fenti kódban hol a hiba?
Most arra tippelek, hogy az
a.resize(aN);-nel így önmagában nem tud mit kezdeni, mert
em tudja mivel kellene feltölteni. Szóval most megcsinálom, hogy
a, belepush_back()-elek egy üresvector<int>-et és azt töltögetem egyenként vagy
b, feltöltök egy teljesvector<int>-et és aztpush_back-elem egészben avector<vector<int>>-be -
joysefke
veterán
Ezer éve nem foglalkoztam C++-szal, most szeretném felhozni magam, de a legegyszerűbb dolgok sem működnek. A kétezres évek elején ragadtam..
Meg tudná valaki légyszi mondani, hogy a konkrét kódban mi a hiba?
vector<vector<int>> struktúrát szeretnék létrehozni, és soronként inicializálni.
-a bemenet első sora megadja, hogy a vector<vector<int>> struktúra hány sorból álljon, ezt az aN változóban tárolom.
-a bemenet következő soraaian első eleme egy-egy integer, ami megmondja, hogy az adott sorban tárolt vector<int> struktúra hány elemet fog majd tartalmazni. A további elemek pedig a sorban tárolt vector<int>-nek az egyes egész számai.int main() {
int aN = -1;
cin >> aN ; //vektor sorainak száma
string line; // soronként olvasom és parsolom a bemenetet
int temp;
vector<vector<int>> a;
a.resize(aN); // foglalok aN darab sort. Nem tudom mit használ default értékként feltöltésre
for (int i = 0; i != aN; ++i) {
getline(cin, line); //adatok beolvasása soronként
istringstream s(line);
s >> temp; //a sor első eleme megmondja, hány elemű lesz a sorban tárolt vector<int>
a[i].reserve(temp);
while (s >> temp) { //parsoljuk a beolvasott sort, minden integert beleírunk a sor végére
a[i].push_back(temp);
}
}
return 0;
}
Új hozzászólás Aktív témák
● olvasd el a téma összefoglalót!
- Kamionok, fuvarozás, logisztika topik
- CADA, Polymobil, és más építőkockák
- Mobilinternet
- Genshin Impact (PC, PS4, Android, iOS)
- Router gondok
- Gépész 3D tervezőrendszerek
- LEGO klub
- iRacing.com - a legélethűbb -online- autós szimulátor bajnokság
- Nem indul és mi a baja a gépemnek topik
- Modding és elektronikai kérdések
- További aktív témák...
- BESZÁMÍTÁS! MSI B760M i5 14400 16GB DDR5 512GB SSD RX 6700 XT 12GB Lian LI LANCOOL 207 GIGABYTE 750W
- Lenovo ThinkPad L16 Gen 1 - 16" WUXGA IPS - Ultra 5 135U - 16GB - 512GB - Win11 - 2,5 év gari
- Akció! HP ZBook Firefly 14 i7-1165G7 16GB 512GB Nvidia Quadro T500 4GB 14" FHD 1 év garancia
- Game Pass Ultimate előfizetés azonnal, problémamentesen, méghozzá OLCSÓN! Immáron 8 éve!
- iPhone Air 256GB BONTATLAN (1év Gyártói Garancia)
Állásajánlatok
Cég: Laptopműhely Bt.
Város: Budapest


