Plik nagłówkowy wektor.h
struct wektor { int rozmiar; double *wartosc; }; struct wektor *alokuj(struct wektor * w, int n); void zwolnij(struct wektor *w) struct wektor *kopiuj(struct wektor *w1, struct wektor *w2); double dlugosc(struct wektor *w); double iloczyn(struct wektor *w1, struct wektor *w2); struct wektor *unormuj(struct wektor *w1);
Zdefiniuj odpowiednie funkcje w pliku źródłowym wektor.c
i napisz program demonstrujący ich działanie.
Napisz program generujący słownik w oparciu o drzewo binarne. Dla podanego pliku (lub po wczytaniu tekstu ze strumienia wejściowego) program wyświetla posortowaną alfabetycznie listę występujących w tekście wyrazów oraz liczbę wytapiań danego wyrazu w tekście.
Plik nagłówkowy slownik.h:
struct drzewo { char *slowo; int ilosc; struct drzewo *left, *right; }; struct drzewo* dodaj(struct drzewo *d,char *slowo); void wyswietl(struct drzewo *d);
Funkcja dodaj(struct drzewo *d,char *slowo) dodaje nowe słowo do słownika (drzewa). Wartością zwracaną jest wskaźnik do bieżącego węzła w drzewie. Słowo umieszczane jest w drzewie zależnie od kolejności słownikowej (alfabetycznej).
Funkcja wyswietl(struct drzewo *d) wypisuje zawartość słownika, czyli posortowaną listę słów wraz z liczbą wystąpień danego słowa w pliku.
slownik.exe plik_tekstowy
[a-zA-Z]
). Wszystkie pozostałe znaki są separatorami wyrazów. Dla ułatwienia można zaimplementować funkcję getword, która pobiera kolejne słowo se strumienia (wejściowego, z pliku). Funkcja wczytuje do tablicy pierwsze napotkane w strumieniu słowo (po pominięciu wszystkich początkowych znaków które nie są literami) i zwraca wartość sygnalizującą czy słowo zostało wczytane (np. może zwracać długość słowa gdzie wartość 0 zwracana jest w przypadku dotarcia do końca strumienia w którym nie wystąpiło już żadne słowo).
Jakiej ważnej funkcji brakuje w pliku slownik.h ?
Zaimplementuj ją.
Przydatne funkcje:
malloc()
i free()
na wywołania operatora new
i delete
<iostream>
do wczytywania i wyświetlania słów z terminala lub pliku<string>
zamiast tablic char*
do zapamiętywania słów słownikastruct
przy deklaracjach zmiennych typu drzewo
dodaj()
i wyswietl()
przepisz jako metody publiczne tej klasy (Zobacz zadanie Słownik obiektowo)