Diskuze: Citanie int v C
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.

Tvůrce

Zobrazeno 27 zpráv z 27.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí C++, jsme si ověřili nabyté zkušenosti z kurzu.
EOF je makro indikující konec souboru, ty ale načítáš z konzole a ta je považována ze nekonečný souboru tedy na EOF nikdy nenarazíš.
Presne tak, stdin a efektívne sa používajú pri práci so súbormi.
eof, nie efektívne
scanf vracia pocet uspesne nacitanych dat alebo EOF ak nastala chyba hned na
aciatku. (http://en.cppreference.com/…/io/c/fscanf).
podmienk by mala vyzerat takto:
(scanf("%d ",pole+i) == 1)
zdá sa, že tvoje riešenie je v c++, alebo sa mýlim?
V tomto by nemal byt rozdiel medzi c a c++.
int i;
assert(scanf("%d%d", &i, &i) == 2);
To čo si napísal predtým, nefunguje.
#include<stdio.h>
#include<stdlib.h>
int main()
{
int i=0, pole[50];
while (scanf("%d", pole + i) == 1)
i++;
printf("KONIEC!\n");
return 0;
}
V prvej správe je zadanie: vo formate: %d %d %d .... teda cele cisla oddelene medzerou (presny pocet nieje zadany a vypis konci s EOF)
Ved zadaj celé čísla oddelene medzerami a ukonči ich s EOF a bude to fungovať.
Poraď mi ako zadám EOF.
Sorry, už som to skúsil, nevedel som, že je niečo také možné.
Konečne tomu rozumiem. Asi my to dnes veľmi nemyslí.
Podmienka: (scanf("%d ", pole+i) == 1)
je splnená, ak je zadaný výraz TRUE a nesplnená, keď je FALSE.
Teda vlastne pod EOF sa myslí, čokoľvek iné ako int.
Tak som sa k tomu konecne dostal a zistil som ze to stale neviem zistit ... prikladam kod /* teraz som pre zmenu prisiel na to ze neviem pracovat s malloc() */
int *cisla;
int k=1;
cisla=(int*)malloc(k*sizeof(int));
while (1)
{
switch (scanf("%d",&cisla[k-1]))
{
case 1:
{
k++;
cisla=(int*)malloc(k*sizeof(int));
}
break;
case EOF: goto out;
default:
{
printf("Nespravny vstup.\n");
return 0;
}
}
}
out:
Mal by si najpr prkeopyrovat prvky so stareho pola do noveho(napr
memmove/memspy) a az potom prepisat pointer 'cisla'. Nasledne by si mal stare
pole zmazat pomocou free. Jednoduhsia verzia je pomocou realloc co za teba
prekopyruje a zmaze stare pole (niekedy sa podari rozsirit pamet bez mazania
starej tak to bude aj rychlejsie). Ten cyklus by sa dal napisat aj bez goto
ktoremu je dobre sa vyhybat ak je to mozne (niekedy sa hodi ale toto nie je ten
pripad).
edit: allokacia je dost pomala, preto je lepsie alokovat po vecsich blokoch.
No je tam spusta divného kódu.
Ten druhý malloc ve switchi vytvoří vždy nové pole a k tomu starému se už
nikdy nedostaneš, protože přepíšeš starou adresu. Takže ve výsledku
máš N polí pro N zadaných čísel a v každém poli je
zapsané jen číslo pro poslední prvek. Funkci, kterou hledáš pro
zvětšování pole je realloc.
Taky není nejlepší realokovat pro přidání nového prvku, ale vždy
alokovat místo pro víc položek pole a teprve až dojde místo, tak třeba
zdvojnásobit velikost. Tím se ale asi zatím nemusíš zabývat, když ještě
neumíš pořádně ani základy.
A ten příkaz goto nepoužívej u takového případu, kdy je na první pohled
jasné, že není vůbec potřeba.
Jestli jsem teda pochopil, co chceš, tak by to mohlo vypadat tak nějak:
#include <stdlib.h>
#include <stdio.h>
int main(int argc, char** argv)
{
int k = 1;
int *cisla = (int*)malloc(k*sizeof(int));
while (scanf("%d", cisla + (k - 1)) != EOF)
{
int cislo = cisla[k - 1];
if (cislo == 1)
{
k++;
cisla = (int*)realloc(cisla, k * sizeof(int));
}
else
{
printf("Nespravny vstup.\n");
return 0;
}
}
return 0;
}
to je to co som potreboval, tomu goto som sa chcel aj ja vyhnut ale nevedel
som ako dva krat breaknut vo switchy a nenapadlo ma ho uplne vynechat,
dakujem pekne za pomoc
toto ti nebude fungovat, tvoj cyklus sa ukonci po prvom prechode
// ok bude nevsimol som si to continue
Zobrazeno 27 zpráv z 27.