Új hozzászólás Aktív témák
-
JoJ
csendes tag
Na ide is leírom, hátha többen olvassák: (boccs a noob kérdésekért...)
strcpy függvénystrcpy (s, t)
char *s, *t;
{
while (*s++ = *t++)
;
}Mi az s és a t?
Mi a *s, *t?
Mi a *s++ és a *t++, és mit csinál?
Hogyan "tudja" a while, hogy mikor van vége a szövegnek?
(az nem kielégítő válasz, hogy megkeresi a 0-át a string végén!)[ Szerkesztve ]
-
Jester01
veterán
válasz #25954560 #250 üzenetére
1. Igen, alapvetően jobb az operációs rendszerre hagyni a magok kezelését, de bele lehet szólni.
2. Ha nem tudsz dinamikusan szétosztani tetszőleges szálra, akkor írd meg 8ra, igen.
3. Nem értem mit akarsz a memóriaterülteteken optimalizálni. Lehet, hogy csak nem ismerem ezt a technikát.Jester
-
doc
nagyúr
akkor a másik totyikba már nem válaszolok
szóval:s az a cím (ha úgy tetszik, string) ahova a t címen tárold string bemásolódik
char *s annyit jelent, hogy az s változó egy karakterre mutató mutató lesz
*s++ ez annyit művel, hogy megadja azt az értéket, amire az s változó mutat, majd az s értékét növeli, így az a következő karakterre fog mutatni
a while onnan tudja hogy vége a szövegnek, hogy a t változó, ami minden ciklusban a következő karakterre mutat, 0-ra fog mutatni, ami meg ugye string vége
így az s által mutatott helyre 0 kerül, ezt a visszatérési értéket a while is látja, és mivel 0, amit ő "hamis"-ként értelmez, végezremélem vmennyire érthető volt...
-
Jester01
veterán
- s és t a cél illetve a forrás paraméter
- *s és *t az aktuális karakter
- a *s++/*t++ eltárolja/visszaadja az aktuális karaktert majd növeli a pointert, hogy a következő kartakterre mutasson
- pedig a while bizony onnan tudja, hogy vége a szövegnek, hogy összetalálkozik a lezáró 0-val. Máshonnan nem is tudhatjaJester
-
#25954560
törölt tag
válasz Jester01 #252 üzenetére
koszi.
nem a memoriateruleteken akarok optimalizalni, csak rosszul fogalmaztam. a hozzaferesekkel van bajom. valami szemafort muszaj lesz hasznalni, ehhez viszont kell szinkronizacio a szalak kozott. ha tobb szal matathat egyszerre ugyanabban a tablaban, akkor abbol baj lehet.
tovabb bonyolitja a dolgot, hogy mi van a virtualis gepben futo cuccossal? akkor bizony maga a virtual machine kell hasznaljon tobb magot, mert belul en nem kell tudjam mi van alatta. ajjajjaaaaajjj -
JoJ
csendes tag
Nagyon-nagyon szépen köszönöm!
-
JoJ
csendes tag
Még annyit kérdeznék (ha jól emlékszem azt is kérdezte), hogy az s és a t milyen állomány?
Gondolom szöveges...[ Szerkesztve ]
-
JoJ
csendes tag
Na végre megvan!
megjegyzés.: a while olvassa a stringet és közben vizsgálja, hogy 0 e, így ha a string végére ér (ami 0), akkor kilép a ciklusból
-
supesz
aktív tag
Hello,
Tud vki ajánlani vmi windowsos c compilert?
Az 1hsz-be volt ez a devc++ vagy mi. Az fordítja a sima c nyelvet is? Igazából vmi windows alatt futó cucc kellene, mert az a régi kék képernyő nem olyan szimpi.
Tud vki valamit esetleg ajánlani?A nucleus arcuatus (infundibularis) kapillárisaiból összeszedődő vénák a hypophysisnyélen keresztül lejutnak a hypopisis elülső lebenyébe - az adeno-hypopisisbe, és ott újra kapillárisokká oszlanak.
-
supesz
aktív tag
Most töltöm.
Megnézem milyen. Előtte leszedtem a MiracleC Compilert, de nem tudom mi nem jó neki. A könyvből másolom be neki a példát, de nem fordítja le. Ráadásul nem engedi beírni a könyvtári fügyvény hívására vonatkozó sort sem. Mi lehet vele?! Nem tudom.
Remélem ez a Dev jobban muzsikál majdA nucleus arcuatus (infundibularis) kapillárisaiból összeszedődő vénák a hypophysisnyélen keresztül lejutnak a hypopisis elülső lebenyébe - az adeno-hypopisisbe, és ott újra kapillárisokká oszlanak.
-
supesz
aktív tag
Nagyon jó.
A nucleus arcuatus (infundibularis) kapillárisaiból összeszedődő vénák a hypophysisnyélen keresztül lejutnak a hypopisis elülső lebenyébe - az adeno-hypopisisbe, és ott újra kapillárisokká oszlanak.
-
plaschil
aktív tag
Sziasztok!
Erre a kérdésre tudja valaki a választ?
Írjon makrófüggvényt, ami két síkbeli pont távolságát számítja ki.
Ugye a két pont távolságát úgy számoljuk ki, hogy adott az x1, x2, és y1, y2. Ha x2-ből kivonom az x1-et, megkapom a derékszögű háromszög egyik oldalát, amely ugye az x tengellyel párhuzamos. Ugyanígy y2-ből y1-et ha elveszem, megkapom a derékszögű háromszög másik oldalát, ami meg ugye az y tengellyel párhuzamos. Ha összekötöm a két pontot, akkor megkapom a derékszögű háromszög átfogóját. na már most ha ismerek két oldalt, és a háromszög derékszögű, akkor alkalmazhatom a Pitagorasz-tételt.
Na ezt kéne valahogy felírni egy makrófüggvénnyel.
Én valami ilyesmit írtam vizsgán:#define C = sqrt(a*a+b*b, 1/2);
Creative G500 vezérlő panelt keresek// Hol vagy helyileg? - A kisszobába. // Szilvásbuktát, mert azt szeretem!
-
doc
nagyúr
válasz plaschil #264 üzenetére
inkabb:
#define TAVOLSAG(x1,y1,x2,y2) sqrt(((x1)-(x2))*((x1)-(x2))+((y1)-(y2))*((y1)-(y2)))
fejbol irtam, szoval nem biztos hogy jo
a sok zarojel (minden parameter kore) azért kell, hogy na nem egyetlen szammal, hanem vmilyen kifejezessel hivod meg, ne kavarodjon ossze, mivel ez csak sima szoveghelyettesites
[ Szerkesztve ]
-
odonye
csendes tag
Sajnos egy nagyon hülye kérdésem lenne. Mivel mostnában egy jóideig nem programozgattam, és előtte is írtózatossan kezdő voltam, msot felmerült egy problémám. Függvények, amik(ha jól emlékszem) előtte működtek, most nem.
PL:
int main()
{
int a
printf("%d",valami(a));
}
valami(b);
int valami(b);
{
int c;
c=5;
return (c);
} -
doc
nagyúr
ezek előtte sem működtek
int main()
{
int a
printf("%d",valami(a));
}ez eddig OK, csak az "int a" végére kell egy pontosvessző
valami(b);
ez viszont a levegőben lóg, a main-en kívül van, így nem jó
int valami(b);
{
int c;
c=5;
return (c);
}ez meg majdnem jó (ha azt akarod hogy 5-öt adjon vissza), csak a fejléc nem, helyesen:
int valami(int b)
{
... -
odonye
csendes tag
Köszönöm, pontos vessző, pedig csak gépelési hiba.
-
CrusherW
tag
válasz plaschil #264 üzenetére
Hello.
Unalom űzésként találtam ezt a topicot, ide legalább tudok írogatni
Előszöris, sajna csak C# ban tudom elmondani az én megoldásomat, de remélem az is segít:
először is, az oké, hogy kivonod X2 - X1 et, és Y1 ből Y2 őt, de ugye, arra is gondolj, hogy a két pont közül nem tudod, melyik hol, van, tehát először megkell állapítani, hogy melyik a nagyobb, és nagyobból a kisebbet számold ki.
public double GetDistance(PointF p1, PointF p2)
{
double xDistance = Math.Max(p1.X, p2.X) - Math.Min(p1.X, p2.Y);
double yDistance = Math.Max(p1.Y, p2.Y) - Math.Min(p1.Y, p2.Y);return Math.Sqrt(Math.Pow(xDistance, 2) + Math.Pow(yDistance, 2));
}ezt aztán egysorossá is lelehet redukálni, nah meg PointF objektum helyett lehet több double, int, decimal, vagy neked tetsző változót használni. Lehet, hogy nem tökéletes mert notepadba lehet elírtam valamit, de sztem ez jó lesz
-
feherpeter
csendes tag
Hello!
main()
{
char ch[3];
ch = "123";
printf ("%s", ch);
}A 4. sorban azt mondja hogy Lvalue required. De hát ott van nem? Vagy mi a baj vele?
-
doc
nagyúr
válasz feherpeter #270 üzenetére
a 3 kevés lesz, ha karaktert akarsz beletenni akkor 4 eleműnek kell lennie, mert tárolni kell a stringvégi lezáró 0-t is
a ch="123" helyett meg az strcpy(ch, "123") formát használd, mert így csak a mutatót írod át (ami elvileg működik, de ne szokjunk rá... ) -
odonye
csendes tag
Hogyan tudnék gyököt vonni?
-
Vico87
tag
válasz CrusherW #269 üzenetére
Igazából nem kell megnézni, hogy valamelyik nagyobb-e. Mert ugyanis négyzetre emeled, ami után mindenképp nemnegatív értéket kapsz.
Az újabb C szabványban már van inline függvényekre támogatás. Azzal szerintem a legjobb egy ilyet megoldani.
Valahogy így :inline tavolsag(int x1, int x2, int y1, int y2) {
return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2) );
}(Bár a Visual Studio 2005 nem eszi meg C esetén az inline függvényt)
[ Szerkesztve ]
-
Retekegér
HARDVERAPRÓD
Az normális, ha Windows környezetben szempillantás alatt lefut a program és be is zárja az ablakot? Még akkor is, ha egy kamuváltozót akarok beolvastatni a program végén. (Dev-C++-t használok)
<< Heimdal >>
-
Lortech
addikt
válasz Retekegér #277 üzenetére
Normális olyan értelemben, hogy vsz. nem bug. Nem normális olyan értelemben, hogy gondolom nem ezt szeretnéd. Esetleg bennemarad a pufferben valami az előző beolvasásokból, ezért egyből lefut a beolvasás. Ha bemásolod a kódot, akkor egyértelművé tehető. A system("PAUSE"); a program végén nem szép megoldás, és kerülendő is valódi alkalmazásoknál, de tesztelni és tanulgatni megteszi az előbbi figyelembevételével.
[ Szerkesztve ]
Thank you to god for making me an atheist
-
-
Lortech
addikt
válasz Retekegér #279 üzenetére
Uff. Szóval if után nem teszünk ;-t, hacsak nem egy üres utasítást akarsz szimbolizálni.
Itt most az történt, hogy az igaz ágadban lett egy üres utasítás (;). Majd jön egy blokk ( {} )ami mindig lefut az előbbi if-től függetlenül, így persze egyből kilép az exit miatt.
Meg az ilyen exit(-1) is felesleges, egy if () {} else {} megoldás szimpibb.De hozzán legközelebb az áll, hogy ha a két param sikeresen beolvasódott, akkor csinálsz valamit, egyébként meg nem (nincs else ág sem), és végetér a program a main blokk végén.
[ Szerkesztve ]
Thank you to god for making me an atheist
-
-kdM-
senior tag
hello!
lenne egy keresem egy feladattal kapcsolatban...tehat egy txt-bol beolvasok x szot/nevet es a programmal meg kell szamoltatni melyik szobol/nevbol mennyi van
(nem kell forraskod minta eleg egy hasznalhato otlet mivel nekem mar sokadik megoldasom vallott kudarcot :/ es termeszetesen a programnak "csak" a szamlalo reszere kene tipp) -
Retekegér
HARDVERAPRÓD
Pontosvessző véletlenül maradt benne, ráadásul az exit függvényt tartalmazó stdlib.h állományról is megfeledkeztem. Mindegy.
Így már jobb egy kicsit:#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
main()
{
int a,b,c;
do
{
printf("Kerek ket szamot:");
if (scanf("%d,%d",&a,&b)!=2)
{
printf("Hibas adatbevitel!\n");
continue;
}
c=a+b;
printf("A ket szam osszege: %d+%d=%d\n",a,b,c);
}
while (getch()!=32);
}<< Heimdal >>
-
Lortech
addikt
Például létrehozol egy egyszerű structot két mezővel:
int szam;
char * szo;Aztán implementálsz egy neked szimpatikus dinamikus adatszerkezetet (pl láncolt lista) melynek elemtípusa az előbbi struct és amelyben tudsz keresni a "szo" mezo szerint. Aztán feldolgozod a szavakat, és ha van már egy adott szó a listában, akkor a megfelelő elem szam mezőjéhez hozzáadsz egyet, ha nincs, akkor befűzöl a lista végére egy új elemet. Nyilván itt keményen memóriát kell kezelni, de ez alap.
Thank you to god for making me an atheist
-
Pocak89
aktív tag
Azt meg tudná nekem mondani vki hogyan lehet hagyományos c programot lefordítani/lefuttatni microfos visual studio 2005-ben? mert a "play" gomb az szürke és nemtom mit csináljak. Inkább abban írnám nem turbó c-ben.
Video games ruined my life!!! Good thing I have two extra lives
-
odonye
csendes tag
Abban ,hogy kell nem tudom, de van más megoldás is: Dev C++.
-
feherpeter
csendes tag
Hello!
Az lenne a kérdésem hogy megoldható-e C-ben hogy jpg fájlokat töltök be és megjelenítem őket. -
kicsitomi88
őstag
-
feherpeter
csendes tag
válasz kicsitomi88 #289 üzenetére
Keresgéltem google-n. Majdnem ugyanazt írtam be mint te(open jpg with c source). De ott csak jpg encoder/decoder volt meg open-source. Nézd csak meg ha gondolod.
Tehát azt szeretném hogy megmondom a kép elérési utját és valami változóba eltárolom és azt később megtudom jeleníteni. Most má nem muszály jpg tök mindegy csak valaki segítsen -
doc
nagyúr
válasz feherpeter #290 üzenetére
millió megoldás van, a gugli igenis a barátod
persze a jpg beolvasása önmagában kevés, azt meg is kell jeleníteni, erre szintén sok lehetőséged van, az egyik legegyszerűbb és legjobb az SDL
keresgélj a neten SDL tutorialokat, ezzel a képbetöltés/megjelenítés mellett millió mást is meg tudsz csinálni -
Vico87
tag
File / New / Project, a megjelenõ ablakban pedig "Project type"-nak Visual C++, aztán "Templates" közül pedig "Win32 console application", töltsd ki a "name" és "solution name" mezõket, majd a varázslóban katt az "Application settings"-re, és pipáld be az "Empty project"-et, végül finish. Ezután a "Solution explorer"-ben (ha nincs kint alapból, akkor a View menübõl elõcsalogatható) jobb klikk a "Source files"-ra, "Add / New Item". Válaszd ki bal oldalt a "Code" kategóriát, majd a C++ file-t, névnek viszont adj *.c kiterjesztést (ezzel automatikusan C fordítót használ a VS, és nem C++ fordítót). Copy-paste-eld be a kódot a fájlba, majd futtasd (gyorsbill: Ctrl+F5, debuggerhez pedig F5).
-
D@ni88
addikt
hali, most kezdtünk el a suliban C-t tanulni.
az lenne a kérdésem h itt mit rontottam el.
Gépileg kéne feltöltenie sorba, de nem hagyja magát
esetleg, még azt kérdezném, h a karakteres 2d-s tömböt hogy kell létrehozni vagy csak egyszerűen double-el?#include <stdio.h>
void main()
{
double a[5][5];
int i, j, x, y;
char c;
y=0;
for(i=0; i<5; i++)
{ y=x;
for(j=0; j<5; x=y; j++; x++)
{
a[i][j]=x;
}
}
}[ Szerkesztve ]
-
amargo
addikt
Én azt sem értem, hogy mit szeretnél csinálni?
Ez szépen sorba feltölti 0-24ig a tömbötdouble a[5][5];
int x = 0;
for(int i = 0; i < 5; i++)
{
for(int j = 0; j < 5; j++)
{
a[i][j] = x++;
}
}“The workdays are long and the weekend is short? Make a turn! Bike every day, bike to work too!”
-
D@ni88
addikt
-
Lortech
addikt
1, int x, i, j = 0;
Ez nem azt jelenti, hogy x = 0 i = 0, j= 0, hanem x és y = meghatározatlan és j =0.
2, amiért nem fordul a programod az az, hogy i és j a cikluson kívül is deklarálva van, meg a ciklus fejében is.
3, minek ide a double? Ha %d-vel akarsz kiiratni, akkor pl int-ként deklaráld illetve fordítva, ha double-t akarsz kiiratni akkor "%f" a szimbólum.
Thank you to god for making me an atheist
Új hozzászólás Aktív témák
● olvasd el a téma összefoglalót!
● ha kódot szúrsz be, használd a PROGRAMKÓD formázási funkciót!
- Red Dead Redemption 2 (PC)
- Android szakmai topik
- Nők, nőügyek (18+)
- MILC felhasználók szakmai topikja
- iPhone topik
- Egyéni arckép 2. lépés: ARCKÉPSZERKESZTŐ
- Pécs és környéke adok-veszek-beszélgetek
- Politika
- f(x)=exp(x): A laposföld elmebaj: Vissza a jövőbe!
- NVIDIA GeForce RTX 4080 /4080S / 4090 (AD103 / 102)
- További aktív témák...
- GYÖNYÖRŰ iPhone 14 Pro 256GB Space Black - Kártyfüggetlen, 1 ÉV GARANCIA, 100% Akkumulátor
- iPhone XS - 64GB - Space Gray - Független Eladó!
- Bontatlan ÚJ IPHONE 13 mini 128-512Gb gyári független Minden Szín Deák Térnél Azonnal Átvehető.
- ÉRKEZETT Legújabb Bontatlan Új M2 IPAD PRO 2022 11 128GB - 256GB Wi-Fi Azonnal Deák Térnél Átvehető.
- Újszerű, gyártói garanciális ASUS VIVOBOOK S 14 FLIP TN3402/Ryzen 5 7530u/16 GB DDR4/256 SSD/Tablet