Hirdetés
- Elkészült az SMIC 5 nm-es node-ja, de a kínaiaknak haszna nincs rajta
- Projektor topic
- 5.1, 7.1 és gamer fejhallgatók
- Mesébe illő csodakábelt tervezett a GeForce-ok leégése ellen a Segotep?
- Milyen monitort vegyek?
- Apple asztali gépek
- Sony MILC fényképezőgépcsalád
- Milyen cserélhető objektíves gépet?
- UHD filmek lejátszása
- Autós kamerák
-
PROHARDVER!

Ú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!
- Star Trek
- Anglia - élmények, tapasztalatok
- Yettel topik
- Samsung Galaxy Felhasználók OFF topicja
- Robotporszívók
- Megbüntették, ezért feloszlatná az EU-t Elon Musk
- Vigneau interaktív lokálblogja
- Audi, Cupra, Seat, Skoda, Volkswagen topik
- E-roller topik
- S.T.A.L.K.E.R. 2: Heart of Chornobyl
- További aktív témák...
- GAINWARD GeForce RTX 4070 Ghost 12GB GARANCIÁLIS, DOBOZZAL, SZÁMLÁVAL
- Asus ExpertBook B1403 Core i7 notebook bontatlan dobozában eladó
- Lenovo ThinkPad X1 Nano (Gen2)/13.0"/2160x1350/2K/IPS/i7-1260P/16GB/512GB SSD/Súly 0.966,5kg
- iPhone 16 Pro Max 1 TB Black Titanium
- Karácsonyi akció - MacBook Pro 13" CTO (Early 2015, i7 / 16GB / 512GB)
- Apple iPhone 15 / 128GB / Kártyafüggetlen / 12Hó Garancia / Akku:83%
- Samsung Galaxy S25 Ultra 1024GB/1T Újszerű Kártyafüggetlen 1év Garanciával
- Gamer PC-Számítógép! Csere-Beszámítás! R7 5700X / RX 6700XT 12GB / 32GB DDR4 / 1TB SSD Nvme
- Apple iPhone 12 Pro Max 128GB, Kártyafüggetlen, 1 Év Garanciával
- Xiaomi 14T 25,Újszerű,Dobozával,12 hónap garanciával
Állásajánlatok
Cég: ATW Internet Kft.
Város: Budapest
Cég: PCMENTOR SZERVIZ KFT.
Város: Budapest




