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

Błąd tablic w programie

Object Storage Arubacloud
0 głosów
124 wizyt
pytanie zadane 27 listopada 2017 w C i C++ przez Sic Dyskutant (8,510 p.)

Witam piszę program, który nie jest trudny jednak jest w nim błąd, o którym wiem. Błędem są tablice. Próbowałem wielokrotnie zamienić pętle while na for jednak nie wiem jak dobrać petli warunek aby zakończył wpisywanie liter do pojedynczego znaku. '@'

#include <iostream>
#include <cctype>

int main()
{
    std::cout << "Wpisz zdanie" << std::endl;
    char ch, samogloski[6] = {'a', 'e', 'y', 'i', 'o', 'u'},
         spolgloski[17] = {'b', 'c', 'd', 'f', 'g', 'h', 'j', 'k', 'l', 'm', 'n', 'p', 'q', 'r', 's', 't', 'w', 'z'};
    int licz_spol=0, licz_samo=0, inne=0;
    std::cin.get(ch);
    while(ch != '@') // blad tablic ... 
    {
        if(isalpha(samogloski[6])) licz_samo++; //samogloski
	else if(isalpha(spolgloski[17])) licz_spol++;  //spogloski
        else inne++;// inne znaki
	std::cin.get(ch);
    }//while
    std::cout << licz_samo <<" samoglosek\n" << licz_spol << " spolglosek\n" << inne << " wyrazow\n";
    return 0;
}

Proszę o podpowiedź jak zamienić pętle na for.(warunek pętli).

 

2 odpowiedzi

+1 głos
odpowiedź 27 listopada 2017 przez TenGumis Gaduła (3,440 p.)
wybrane 27 listopada 2017 przez Sic
 
Najlepsza
Ważnym pytaniem jest co ten program ma robić?
komentarz 27 listopada 2017 przez Sic Dyskutant (8,510 p.)
Użytkownika na wpisać zdanie kończąc znakiem '@' (tylko litery, dlatego w programie znajduje się funkcja isalpha())

Program ma wyliczyć ile jest spółgłosek, ile samogłosek i ile wyrazów liczył program.
komentarz 27 listopada 2017 przez TenGumis Gaduła (3,440 p.)
Jeśli pętla while działa poprawnie (a działa) to warunek pętli for moze byyć identyczny czyli może ona wyglądać tak:

    for(; ch != '@';)

Jesli jednak twierdzisz że nie wyglada to elegancko to zobacz że przed pętlą masz zawsze  std::cin.get(ch); więc wrzućmy to do pętli:

    for(std::cin.get(ch); ch != '@';)
I jeszcze możemy zauważyć że wczytujemy zawsze nowy znak na końcu pętli więc możemy usunąc z tamtąd std::cin.get(ch); i również wkleić je do pętli
 

    for(std::cin.get(ch); ch != '@';std::cin.get(ch))

Błędem przez który się to nie kompiluje jest zbyt mała tablica na spółgłoski. Jest ich 18 w twoich klamrach.
I ostatnim głównym problemem jest to że algorytm wewnątrz pętli jest błędny.

if(isalpha(samogloski[6])) to nie jest sprawdzenie czy wczytany znak jest w tablicy samogłosek.
+2 głosów
odpowiedź 27 listopada 2017 przez j23 Mędrzec (194,920 p.)
...
const char * samogloski = "aeyiou";
const char * spolgloski = "bcdfghjklmnpqrstwz";
			 
int licz_spol = 0, licz_samo = 0, inne = 0;
	
while (std::cin.get(ch) && ch != '@')
{        
	if (strchr(samogloski, ch)) ++licz_samo; //samogloski
	else if (strchr(spolgloski, ch)) ++licz_spol; //spogloski
	else ++inne; // inne znaki
} //while

 

komentarz 27 listopada 2017 przez Sic Dyskutant (8,510 p.)
edycja 27 listopada 2017 przez Sic
Sprawdza się tylko przy wprowadzaniu pojedynczych znaków.
1
komentarz 27 listopada 2017 przez Piotr Batko Stary wyjadacz (13,190 p.)

Nie no, działa elegancko. Spróbuj ten kod:

#include <iostream>
#include <cstring>

int main()
{
	const char * samogloski = "aeyiou";
	const char * spolgloski = "bcdfghjklmnpqrstwz";

	int licz_spol = 0, licz_samo = 0, inne = 0;

	char ch;
	while (std::cin.get(ch) && ch != '@')
	{
		if (strchr(samogloski, ch)) ++licz_samo; //samogloski
		else if (strchr(spolgloski, ch)) ++licz_spol; //spogloski
		else ++inne; // inne znaki
	}
	std::cout << "Samo: " << licz_samo << "; Spol: " << licz_spol << "; Inne: " << inne << std::endl;
}

 

komentarz 27 listopada 2017 przez Sic Dyskutant (8,510 p.)
edycja 27 listopada 2017 przez Sic
Tak, mój błąd dodatkowo wprowadziłem ostatnią linię pętli jako std::cin.get(ch);

 

Dziękuję wszystkim za pomoc.

Podobne pytania

0 głosów
5 odpowiedzi 273 wizyt
pytanie zadane 16 października 2017 w C i C++ przez Sic Dyskutant (8,510 p.)
0 głosów
0 odpowiedzi 716 wizyt
pytanie zadane 30 kwietnia 2017 w C i C++ przez niezalogowany
0 głosów
2 odpowiedzi 302 wizyt

92,573 zapytań

141,423 odpowiedzi

319,648 komentarzy

61,959 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!

...