- Luck Dragon: Asszociációs játék. :)
- Magga: PLEX: multimédia az egész lakásban
- mefistofeles: Az elhízás nem akaratgyengeség!
- lkristóf: Prohardver fórum userscript – hogy lásd, mikor neked válaszoltak
- gban: Ingyen kellene, de tegnapra
- D1Rect: Nagy "hülyétkapokazapróktól" topik
- kenand: Hol volt, hol nem volt, Thunderbolt...
- Sub-ZeRo: Euro Truck Simulator 2 & American Truck Simulator 1 (esetleg 2 majd, ha lesz) :)
- sziku69: Fűzzük össze a szavakat :)
- MasterDeeJay: H110-es lapban 10.gen Comet Lake működhet?
-
LOGOUT

Új hozzászólás Aktív témák
-
Skaidy
csendes tag
Üdv!
Remélem jó helyre írok, ha nem akkor sry.
Nem tudtam megoldani egy feladatot és ebben szeretnék segítséget kérni tőletek.A feladat:
Mérje meg a gráf két csúcsa közötti legrövidebb út keresésének Dijkstra algoritmusának hatékonyságát! Töltsön le különböző méretű txt szövegeket (például a www.gutenberg.org-ról), olvassa be a segédprogram segítségével a memóriába, és hozza létre a gráfot. A gráf csúcsai az adott szavak, és két csúcs között fut él, ha a megadott távolságfüggvény kisebb, mint egy előre megadott szám (ezt a programozó állítja be.) Ezen a gráfon végezze el a keresést különböző méretű bemenetekre. Dokumentálja precízen a mérés lépéseit.
Igazából az a gond, hogy órán még érintőlegesen sem vettük Dijkstra-algoritmusát, ami nem a legfőbb probléma, mert interneten utánajárva könnyen megtalálom, hogy hogy is működik. Viszont magát a programot sem látom át (mivel keveset programoztam még C++ban, inkább csak C-ben), meg hogy hogy kéne felfogni egy szöveget gráfokban..
A segédprogram:
// szavankent beolvasunk egy szoveget
// a szavakat kisbetusitjuk, kitoroljuk a nem betuket
// az eredmenyt rendezzuk, toroljuk az ismetlodeseket
// es elmentjuk az a[] tombbe#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
const int Z=10000000;
string a[Z];
string b[Z];
//ha nagyon nagy meretu tombot foglalunk le,
//azt vagy dinamikusan tudjuk megtenni (new fuggveny)
//vagy globalis valtozokent
int N=0;void beolvas(){
string st;
int i,j,k,s;
ifstream fin("robinson.txt");
while(fin>>st){
s=st.size();
for(k=0,i=0;k<s;k++){
if(st>='A'&&st<='Z')st-='A'-'a';
//nagy betu -> kisbetu
if(st<'a'||st>'z')st.erase(st.begin()+i);
//ami nem betu kitoroljuk
else i++;
}
if(st.size()>0)b[N++]=st;
//ha maradt a szobol berakjuk a tombbe
}
sort(b,b+N);
a[0]=b[0];
st=b[0];
j=0;
for(k=1,i=1;k<N;k++){
if(b[k]!=st){a[i++]=b[k];st=b[k];j=0;}
else if(j<2){ //a 2-o atirhato, ha ugy tartja szuksegesnek!
a=b[k];
j++;
for(s=0;s<j;s++)a+='q';
i++;
}
//ha nincs ismetlodes, elmentjuk az a[] tombbe
//ha van, akkor irjunk moge egy 'q' betut, de max 2-ot, vagy irja at!
}
N=i;
cout<<"N: "<<N<<endl;
}int htavolsag(string a, string b){
//visszaadja, hogy betuk szerint mi a ket string tavolsagaif(a==b)return 0;
string tmp;
if(a.size()>b.size()){tmp=a;a=b;b=tmp;}int x,z=0,f;
for(x=0;x<a.size();x++)
z+=(a[x]!=b[x]); //hany db betuben kulonbozik
z+=b.size()-a.size(); //+szohossz kulonbseg
z=z*z; //negyzetre emeljuk
if(z>25) return 127; //a 0,1,2,3,4,5 betu kulonbsegek elfogadhatoak
//a '127' a vegtelen nagy
else return z;
}Természetesen nem feltétlen kell a kész kódot valakinek elkészíteni, csak iránymutatást szeretnék kérni, és hogy egyáltalán hogy álljak neki, és hogy mi a lényege ennek.
Előre is köszönöm.
Új hozzászólás Aktív témák
● olvasd el a téma összefoglalót!
- Fejhallgató erősítő és DAC topik
- Google Pixel topik
- nVidia tulajok OFF topikja
- Luck Dragon: Asszociációs játék. :)
- Honor Magic8 Pro - bevált recept kölcsönvett hozzávalókkal
- Elbaltázott tankolás miatt csúszik a NASA Holdutazása
- AMD Ryzen 9 / 7 / 5 9***(X) "Zen 5" (AM5)
- Samsung Galaxy A54 - türelemjáték
- Építő/felújító topik
- Kerékpárosok, bringások ide!
- További aktív témák...
- Apple iPhone 13 Pro 128GB, Akku: 92%, Megkímélt, Kártyafüggetlen, 1 Év Garanciával!
- Samsung Galaxy A72 6/128GB, Megkímélt, Kártyafüggetlen, 1 Év Garanciával!
- Apple iPhone SE 2022 64GB, Akku: 100% Megkímélt, Kártyafüggetlen, 1 Év Garanciával!
- Apple iPhone 13 Mini 128GB Akku: 100%, Normál. Kártyafüggetlen, 1 Év Garanciával!
- Kingston FURY Beast 16GB (1x16GB) DDR5 6000MHz CL30 - XMP/EXPO - 120 hó garancia
- BESZÁMÍTÁS! LENOVO ThinkPad P15 Gen 2 munkaállomás - i7 11850H 16GB DDR4 1TB SSD RTX A2000 4GB W11
- Telefon felvásárlás!! Honor 200 Lite, Honor 200, Honor 200 Pro, Honor 200 Smart
- Dell Precision 7550,15.6,FHD,i7-10850H,16GB DDR4,512GB SSD,RTX 3000 6GB DDR6,WIN11
- BESZÁMÍTÁS! MSI B450M R5 5600X 16GB DDR4 512GB SSD RTX 5060 8GB Zalman S2 TG Cooler Master 650W
- 360 áthajthatós! Dell Latitude 5330 2 in 1 i7-1265U 10magos! 16GB 512GB 13.3" FHD 1 év garancia
Állásajánlatok
Cég: Laptopműhely Bt.
Város: Budapest
Cég: PCMENTOR SZERVIZ KFT.
Város: Budapest


