• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

zliczanie wyrazów które występują więcej niż jeden raz

Object Storage Arubacloud
0 głosów
1,311 wizyt
pytanie zadane 16 lipca 2017 w C i C++ przez Krystek102 Bywalec (2,440 p.)

W pliku dane.txt w oddzielnych wierszach znajdują się słowa o długościach od 2 do 20
znaków, składające się z wielkich liter A, B, C, D, E, F. Odpowiedzi do poniższych
podpunktów umieść w pliku tekstowym wyniki.txt. Odpowiedź do każdego podpunktu
poprzedź literą oznaczającą ten podpunkt.
a) W pliku wyniki.txt podaj w osobnych wierszach:
− ile jest słów w pliku dane.txt występujących więcej niż jeden raz,

oto mój kod :

#include <iostream>
#include <fstream>

using namespace std;

int main()
{
    int ile=0;
string s[1000];
ifstream we("dane.txt");
for(int i=0;i<1000;i++)
{
    we>>s[i];
}
for(int i=0;i<1000;i++)
{
   for(int j=i+1;j<1000;j++)
   {
       if(s[i]==s[j])ile++;
   }
}
cout<<ile<<endl;
    return 0;
}

 

moim zdaniem to chyba powinno działać,niestety,ale liczy ilość niepoprawnie,Panie i Panowie proszę o pomoc :) 

1 odpowiedź

0 głosów
odpowiedź 16 lipca 2017 przez j23 Mędrzec (194,920 p.)
edycja 16 lipca 2017 przez j23

string s[1000];

Użyj std::vectora.

for(int i=0;i<1000;i++)
{
    we>>s[i];
}

Lepiej tak:

int n = 0;

while(we >> s[n]) ++n;

// tu 'n' zawiera liczbę słów w tablicy.

 

for(int i=0;i<1000;i++)
{
   for(int j=i+1;j<1000;j++)
   ...

Serio? Prawie 500000 iteracji, nawet jak w tablicy będą tylko dwa wyrazy? Uwzględniaj w swoich pętlach ilość wczytanych wyrazów.

 

Program zapewne zwraca błędne wyniki, ponieważ ponownie zlicza wyrazy już policzone. Usuwaj z tablicy duplikaty (np. wywołując s[i].clear()), albo przy wczytywaniu sprawdzaj, czy przeczytane słowo występuje w tablicy. Jeśli jest, zwiększasz ile, jeśli nie - dodajesz słowo do tablicy.

Podobne pytania

0 głosów
1 odpowiedź 117 wizyt
pytanie zadane 23 września 2020 w C i C++ przez Famous_D Nowicjusz (150 p.)
0 głosów
0 odpowiedzi 299 wizyt
pytanie zadane 17 listopada 2021 w C i C++ przez Nikon221 Początkujący (340 p.)
0 głosów
3 odpowiedzi 761 wizyt

92,539 zapytań

141,382 odpowiedzi

319,476 komentarzy

61,928 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...