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

Wyszukiwanie w pliku.

Object Storage Arubacloud
0 głosów
191 wizyt
pytanie zadane 5 czerwca 2020 w C i C++ przez FaloY Bywalec (2,180 p.)

Cześć! Mam taką treść zadania: /*Napisz funkcję przyjmującą w parametrze nazwę pliku tekstowego zawierającego ciągi wyrażeń
arytmetycznych. W każdej linijce znajduje się wyrażenie typu:
(a+b)*((c+d)*e)
Twoim zadaniem jest napisanie funkcji, która zwróci wartość true, jeśli wszystkie wyrażenia
w pliku są zbudowane poprawnie, tj. mają poprawnie umieszczone nawiasy. Liczba nawiasów
otwierających musi być zgodna z liczbą nawiasów zamykających, co więcej – nie można zamknąć
nawiasu nieotwartego.
Przykładowo:
System.out.println(czyPoprawneNawiasy(”plik.txt”));
plik.txt: 
(a + b)* ((c + d)* e)
(((a)))
((a + b + c + d)))
((a* c)* d)
Zwróci wartość false, bo w trzeciej linijce jest niepoprawne wyrażenie.Jeśli funkcja znajdzie
niepoprawne wyrażenie, ma nie sprawdzać do końca pliku, ale od razu dać wynik.
*/

 

Jak na razie udało mi się takie coś napisać:

#include <iostream>
#include <fstream>
#include <string>

using namespace std;
string nameOfTextFile = "example.txt";
int pos = 0;
int pos2 = 0;
string line;
void file() {
	fstream fik;
	fik.open(nameOfTextFile , ios::in | ios::out);
	if (fik.good() == true)
	{
		while (getline(fik, line)) {
			while (true) {
				pos = line.find('(', pos++);
				pos2 = line.find(')', pos2++);
				if (pos == string::npos)
					break;
			}
		}
	}
	else { 
		cout << "Error! I can not open the file. The file probably doesn't exist\n" << endl; 
		cout << nameOfTextFile << endl;
	}
}

int main() {
	while (true){
		cout << "( - " << pos << endl;
		cout << ") - " << pos2 << endl;
		cout << "Enter the name of the text file." << endl;
		cout << "> ";
		cin >> nameOfTextFile;
		file();
	}
}

Wszystko fajnie, tylko, że zmienne pos i pos2 nie wyświetlają poprawnych wartości, a dokładnie takie coś wyświetlają:

) - -1
( - 1

Gdzie w notatniku znajduję się tylko takie coś: 

(())

I nie wiem gdzie leży problem, nawet nie wiem czy dobrze zadanie zrozumiałem. Będę wdzięczny za jakąś podpowiedź! 

1 odpowiedź

0 głosów
odpowiedź 5 czerwca 2020 przez LuQ232 Mądrala (7,200 p.)
wybrane 7 czerwca 2020 przez FaloY
 
Najlepsza

Zliczanie nawiasów najłatwiej wykonać używając 

std::count

Źródło:

https://en.cppreference.com/w/cpp/algorithm/count

Przykładowy kod:


#include <iostream>
#include <fstream>
#include <string>
#include <algorithm>
 
using namespace std;
int pos = 0;
int pos2 = 0;
string line;
void file(string txt) {
    fstream fik;
    fik.open(txt, ios::in | ios::out);
    if (fik.good() == true)
    {
        while (getline(fik, line)) {
                pos = count(line.begin(),line.end(),'(');
                pos2 = count(line.begin(),line.end(),')');
            }
    }
    else { 
        cout << "Error! I can not open the file. The file probably doesn't exist\n" << endl; 
        cout << txt << endl;
    }
}
 
int main() {
	string txt;
       
        cout << "Enter the name of the text file." << endl;
        cout << "> ";
        cin >> txt;
        file(txt);
	cout << "( - " << pos << endl;
        cout << ") - " << pos2 << endl;

}

 

Pomogłem Ci w tym jak zliczać nawiasy. Algorytm działania programu już musisz wymyśleć sam. Pamiętaj o tym, że jeżeli liczba nawiasów otwierających zgadza się z liczbą nawiasów zamykających to nie znaczy ze wszystko jest dobrze. 

Dla przykładu 

)))(((

 

Powodzenia!

 

komentarz 5 czerwca 2020 przez tkz Nałogowiec (42,000 p.)
Dlaczego nie użyjesz stosu? Przy ( dodajemy, a przy ) ściągamy. W najgorszym przypadku złożoność będzie taka sama, ale przy optymistycznym i średnim dużo lepsza.
komentarz 5 czerwca 2020 przez LuQ232 Mądrala (7,200 p.)
Racja, korzystając ze stosu będzie szybciej.

Podobne pytania

0 głosów
0 odpowiedzi 391 wizyt
0 głosów
1 odpowiedź 471 wizyt
pytanie zadane 26 października 2021 w C i C++ przez polandonion Mądrala (7,040 p.)
0 głosów
1 odpowiedź 478 wizyt
pytanie zadane 6 czerwca 2020 w C i C++ przez magda_19 Gaduła (3,080 p.)

92,579 zapytań

141,429 odpowiedzi

319,657 komentarzy

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

...