Wprowadzenie do tablic znaków (łańcuchów) w ANSI C
|
|
- Michalina Łukasik
- 8 lat temu
- Przeglądów:
Transkrypt
1 Wprowadzenie do tablic znaków (łańcuchów) w ANSI C Tablice znaków stanowią specjalny rodzaj tablic o budowie ułatwiającej przetwarzanie tekstów. Przetwarzanie obejmuje szereg operacji takich jak tworzenie, modyfikację i przeszukiwanie i konwersje tablicy znakowej na liczbę i liczby na tablicę znakową. Tablice znakowe mogą być definiowane w sposób następujący: main () { char s1[5]; char s2[5 ]="ABCD"; char s3[ ]="abcd"; } Definicje tablic s2 i s3 zawierają też inicjalizację. Tablice znaków zakończone są znakiem \0. Znak ten umożliwia wykrycie końca tablicy, a tym samym umożliwia traktowanie tablic znaków w nieco inny sposób niż zwykłych tablic. Budowa tablicy znaków Przykładowo, tablica s2 ma następującą budowę: 'A" 'B' 'C' 'D' '\0' Tak więc definiując tablicę należy przewidzieć jedną komórkę na znak końcowy '\0'. Stałe łańcuchowe i wskaźniki do znaków Stałe łańcuchowe (stałe typu tablica znaków), np. "Tekst", przechowywane są w pamięci jako tablice znaków z ostatnim elementem równym \0. Stala "Tekst" jest typu char *, czyli wskaźnik do znaku. Wskaźnik do znaku może więc zostać zainicjowany stałą łańcuchową char *ps="tekst"; // sposób 1 Inicjalizacja taka jest równoważna parze instrukcji char *ps; // sposób 2 ps="tekst"; W przypadku sposobu 1 do wskaźnika ps jest przypisywany wskaźnik do tablicy znaków, a nie do *ps ( czyli nie do miejsca wskazywanego przez ps).
2 Wczytywanie i drukowanie tablic znakowych cz.1 W języku C istnieje specjalny deskryptor formatu %s umożliwiający wczytywanie i drukowanie tablic znakowych przy użyciu funkcji scanf i printf, istnieją też funkcje biblioteczne realizujące te operacje. Jeśli zdefiniowano tablicę znakową char s1[5]; to można ją wczytać i wydrukować w poniższy sposób: printf("\ Podaj lancuch :"); scanf( %s,s1); /// nie stosuje się znaku & przed s2, gdyż s2 jest //wskaźnikiem. printf( \n Wczytany lancuch to :%s, s1); Jednak wczytywanie łańcuchów przy użyciu funkcji scanf nie pozwala na wczytanie łańcuchów zawierających spacje, gdyż wczytywanie łańcucha jest przerywane po napotkaniu spacji. Dla takich łańcuchów należy zastosować funkcję gets lub też funkcję fgets. Funkcja gets te ma następujący prototyp: char *gets(char *s); Opis działania funkcji gets: Funkcja wczytuje znaki ze standardowego wejścia ( stdin) aż do momentu napotkania znaku nowej linii (Enter). Wczytywane znaki są wyświetlane na ekranie i zapamiętywane począwszy od miejsca wskazywanego przez s. Znak nowej linii jest zastępowany w łańcuchu znakiem końca łańcucha '\0'. Ciąg wejściowy może zawierać pewne białe znaki (np. spacje i znaki tabulacji poziomej). Funkcja zwraca s, gdy operacja się powiodła, lub NULL w przypadku wystąpienia błędu. Długość wczytywanego ciągu znaków nie jest ograniczana, co przy ciągach dłuższych niż to wynika z rozmiaru argumentu funkcji gets, może powstać uszkodzenie sąsiednich obszarów pamięci. Przykład. Użycie funkcji gets do wczytywania tablicy znakowej. char lan [20]; printf ("\n Podaj lancuch:"); gets(lan); Bardziej uniwersalną funkcją służącą do wczytywania łańcuchów jest fgets. Funkcja fgets ma następujący prototyp: char *fgets(char *s, int n, FILE *stream);
3 Funkcja ta czyta do łańcucha s znaki ze strumienia wejściowego (pliku) określonego przez wskaźnik stream. Funkcja kończy wczytywanie znaków po przeczytaniu n - 1 znaków lub też po pojawieniu się znaku nowej linii. Funkcja wpisuje znak nowej linii do łańcucha. Funkcja zwraca łańcuch lub NULL w przypadku pojawienia się końca pliku lub błędu. Przykład. Wczytywanie tablicy znakowej ze standardowego strumienia wejściowego przy użyciu funkcji fgets. char lan [20]; printf ("\n Podaj lancuch:"); fgets(lan,15,stdin); Do drukowania tablic znakowych można zastosować funkcje puts i fputs. Prototyp funkcji puts ma postać int puts(const char *s); Funkcja wyprowadza łańcuch na wyjście standardowe (stdout) i dołącza znak nowej linii. W przypadku pomyślnej realizacji funkcja zwraca wartość nieujemną, w przeciwnym przypadku EOF. int fputs(const char *s, FILE *stream); Funkcja zapisuje łańcuch s do do strumienia wyjściowego określonego przez wskaźnik stream. Funkcja nie zapisuje do pliku znaku '\0'. W przypadku powodzenia operacji funkcja zwraca wartość nieujemną, w przypadku błędu wartość EOF. Opis funkcji operujących na łańcuchach znaków Poniżej przedstawiono krótkie opisy funkcji związanych z działaniami na tablicach znakowych w języku ANSI C. Poniżej będziemy zamiennie stosować terminy tablica znaków, tekst i łańcuch. Oznaczają one tutaj ten sam typ danych. Format oznacza dopuszczalną postać tablicy znakowej. 1. Plik stdlib.h double atof(const char *s) Przekształca tekst zawarty w s na wartość typu double, funkcja rozpoznaje wartość zmiennoprzecinkową reprezentowaną przez s. Funkcja rozpoznaje również wartość
4 nieskończoną, podczas działania tej funkcji pierwszy nierozpoznany znak kończy jej działanie. Format: [biały_znak] [znak] [ddd] [.] [ddd] [eie[znak]ddd]. int atoi (const char *s) Przekształca tekst zawarty w s na wartość typu int (wartość całkowitą), funkcja rozpoznaje tabulator i spację, znak oraz ciąg cyfr. Przepełnienie jest niezdefiniowane. Funkcja zwraca przekształconą wartość lub 0. Format: [biały_znak] [znak] [ddd]. long atol(const char *s) Przekształca tekst zawarty w s na wartość typu long. Działanie jest podobne do działania funkcji atoi z tą różnicą, że wartość zwracana jest typu long. Format: [biały_znak] [znak] [ddd]. double strtod(const char *s, char **endptr) Przekształca tekst zawarty w s na wartość typu double (podobnie jak atof), jeżeli argument wywołania odpowiadający parametrowi endptr jest różny od NULL, funkcja wstawia pod adres wskazany przez ten argument wskaźnik do dalszej części tekstu, która nie została przekształcona. Przepełnienie zwraca HUGE_VAL z odpowiednim znakiem. W przypadku niedomiaru zwracane jest 0. Format: [biały_znak] [znak] [ddd] [.] [ddd] [eie[znak]ddd]. long strtol (const char *s, char **endptr, int base). Przekształca tekst zawarty w s na wartość typu long (podobnie jak atol). Jeżeli argument wywołania odpowiadający parametrowi endptr jest różny od NULL, funkcja wstawia pod adres wskazany przez ten argument wskaźnik do dalszej części tekstu, która nie została przekształcona. Jeśli argument odpowiadający parametrowi base (podstawa systemu liczbowego) zawiera się w przedziale 2-36, to przekształcenia dokonuje się przy założeniu, że tekst wejściowy zawiera liczbę zapisaną przy tej podstawie. Gdy argument odpowiadający parametrowi base równa się 0, wówczas przyjmowana podstawa systemu liczbowego zależy od postaci liczby zapisanej w tekście s. Wtedy, jeżeli liczba rozpoczyna się 0, podstawą będzie 8, jeżeli 0x(lub 0X) podstawą będzie 16, a w pozostałych przypadkach 10. Przy nadmiarze zwracana jest wartość LONG_MAX lub LONG_MIN (zależnie od znaku). Format: [biały_znak] [znak] [0] [x] [ddd]
5 unsigned long strtoul (const char *s, char **endptr, int base) Przekształca tekst zawarty w s na wartość typu unsigned long (działa podobnie do funkcji strtol ) i w przypadku błędu zwraca wartość ULONG_MAX. Format: [biały_znak] [znak] [0] [x] [ddd] 2. Plik string.h W pliku tym zamieszczono deklaracje dwóch grup funkcji operujących na tablicach znaków. Pierwsza to funkcje, których nazwy rozpoczynają się od str, druga to funkcje o nazwach rozpoczynających się od mem. Funkcje, których nazwy rozpoczynają się od str to: strcpy, strncpy, strcat, strncat, strcmp, strncmp, strchr, strrchr, strspn, strcspn, strpbrk, strstr, strlen, strerror, strtok, strlwr, strupr. char strcpy (char *s, const char *ct)' Kopiuje zawartość tablicy znaków ct do tablicy s łącznie ze znakiem '\0'; zwraca s. Funkcja nie sprawdza długości tablicy, do której odbywa się kopiowanie, stąd tablica docelowa musi mieć miejsce na co najmniej n+ l znaków, gdzie n to ilość znaków w tablicy ct. char strncpy (char *s, const char *ct, size_t n) Kopiuje znaki z tablicy znaków ct do tablicy s, jednak nie więcej niż n znaków. Jeżeli w ct jest mniej niż n znaków, puste miejsce dopełniane jest znakami \0. Funkcja zwraca s. char strcat (char *s, const char *ct) Dopisuje znaki z tablicy znaków ct na koniec tablicy s, zwracane jest s. char strncat(char *s, const char *ct, size_t n) Dołącza co najwyżej n znaków z tablicy ct do końca tablicy s, tablica s kończy się znakiem '\0'. Funkcja zwraca s. char strcmp (const char *cs, const char *ct) Porównuje tablice znaków cs i ct. Zwracana jest: wartość <0 dla cs < ct
6 wartość 0 dla cs jest równego ct wartość >0 dla cs > ct. Porównywanie rozpoczyna się od pierwszego znaku obu tablic do momentu, gdy znaki będą się różnić lub do osiągnięcia końca jednej z tablic. Kryterium porównania jest wartość kodu ASCII danego znaku. char strncmp (const ch ar *cs, const char *ct) Funkcja ma podobne działanie jak funkcja poprzednia z tą różnicą, że porównywanych jest co najwyżej n znaków. char *strchr (const char *cs, int c) Zwraca wskaźnik do pierwszego wystąpienia znaku c w cs. w wypadku nie wystąpienia tego znaku zwracane jest NULL. char *strrchr (const char *cs, int c) Zwraca wskaźnik do ostatniego wystąpienia znaku c w tablicy cs. Jeśli znak nie występuje, zwracane jest NULL. size_t strspn (const char *cs, const ch ar *ct) Zwraca długość przedrostka w tablicy cs składającego się ze znaków występujących w tablicy ct. size_t strcspn (const char *cs, const char *ct) Działa podobnie jak poprzednia funkcja z tym, że zwraca długość przedrostka w cs składającego się ze znaków nie występujących w ct, funkcja przerywa zliczanie, gdy w cs napotka znak występujący w ct. char *strpbrk (const char *cs, const char *ct) Zwraca wskaźnik do pierwszego wystąpienia w tablicy cs któregokolwiek ze znaków z tablicy ct. W przypadku nie znalezienia żadnego znaku zwraca NULL. char *strstr (const char *cs, const char *ct) Zwraca wskaźnik do pierwszego wystąpienia cs w tablicy ct lub wartość NULL.
7 size_t strlen (const char *cs) Zwraca długość tablicy cs bez uwzględnienia końcowego znaku '\0'. char *strerror (size_t n) Zwraca wskaźnik do tekstu komunikatu odpowiadającemu błędowi o numerze n. Wywołana bez numeru wypisuje komunikat o ostatnim napotkanym błędzie. char *strtok (char *s, const ch ar *ct) Wyszukuje w tablicy s ciągi znaków przedzielone znakami z tablicy ct. Kolejne wywołania tej funkcji dzielą tablicę s na ciągi znaków rozdzielone znakami z tablicy ct. Funkcja po wywołaniu znajduje pierwszy ciąg znaków nie należących do ct. Znak następny zastępowany jest znakiem /0 i zwracany jest wskaźnik do początku tego ciągu. Każde następne wywołanie tej funkcji musi być z argumentem s równym NULL, wówczas zwracany jest kolejny ciąg znaków, przy czym szukanie rozpoczyna się za końcem poprzedniego ciągu. Zwraca NULL, gdy nie znajduje ciągów. Każde następne wywołanie może być z innym argumentem ct. char *strlwr(char *s); Zamienia w tablicy s litery duże na małe. Pozostałe znaki nie są zmieniane. Zwraca wskaźnik do s. char *strupr(char *s); Zamienia w tablicy s litery małe na duże. Pozostałe znaki nie są zmieniane. Zwraca wskaźnik do s. Funkcje mem Funkcje te to memcpy, memmove, memcmp, memchr, memset. void *memcpy (void *s, const void *ct, size_t n) Kopiuje n znaków z obiektu ct do obiektu s i zwraca s. void *memmove (void *s, const void *ct, size_t n) Wstawia n znaków z obiektu ct do obiektu s i zwraca s. Różni się od memcpy tym, że pozostawia w obiekcie s jego końcową część, jeżeli obiekt s ma większą długość niż obiekt ct.
8 int memcmp (void const *cs, const void *ct, size_t n) Porównuje początkowe n znaków zawartych w obiektach ct i cs. Zasada porównywania jest taka sama jak dla funkcji strcmp. Zwracana jest: wartość <0 dla cs < ct wartość 0 dla cs równego ct wartość >0 dla cs > ct. ~ void *memchr (void const *cs, int c, size_t n) Zwraca wskaźnik do pierwszego wystąpienia znaku c w obiekcie cs lub wartość NULL, gdy znaku c. Sprawdza tylko n początkowych znaków. void *memset (void *s, int c, size_t n) Wstawia znak c do początkowych n znaków obiektu s. Zwracane jest s. // Uzupełnić program o wywołania funkcji z <stdlib.h> #include <conio.h> #include <string.h> #include <stdlib.h> #include <ctype.h> #include <stdio.h> #include <errno.h> int main (int argc, char* argv[ ]) { int i=0,w,dl,ilosc; char *lancuch0 = "AAAAAA"; char *lancuch1 = "BBBBBBB"; char *lancuch2 = "CCCCCCCAAA"; char *lancuch3 = "DDDDDDDDDBBB"; char *lancuch4= "EEEEEEEEEE"; char *lancuch5="fffffffff"; char *string1 = "123CD "; char *string2 = "123DC8";
9 char *lancuch1_1 = "AAA BBB CCC "; char *lancuch2_2 = " "; char *lancuch3_3 = "AAABBBcCC"; char *bufor; char *wskaznik, znak = 'c'; char *wsk1 = "aaabbbccc", *wsk2 = "bbbccc", *wsk3 = "cccddd"; char kopia[40]; char kopia_n[40]="abcdefghikl"; char kopia_1[40]; char kopia_5[40]; char zmienna1[50],zmienna2[50],zmienna3[50]; printf("\n\n\tdzialanie funkcji strcpy :"); printf("\n\n Wywolanie strcpy(kopia, lancuch0) powoduje skopiowanie tablicy znakowej"); printf("\n lancuch0 do tablicy kopia"); strcpy(kopia, lancuch0); printf("\n\n Po skopiowaniu lancuch0=%s kopia=%s", lancuch0,kopia); printf("\n\n\tdzialanie funkcji strncpy dla kopiowania 5 znakow"); printf("\n\n Wywolanie stnrcpy(kopia, lancuch0) powoduje skopiowanie 5 pierwszych"); printf ("\n znakow z lancuch0 do kopia_5"); strncpy(kopia_5, lancuch0,5); kopia_5[5]='\0'; printf("\n\n Po skopiowaniu lancuch0 =%s kopia_5=%s", lancuch0,kopia_5); printf("\n\n\tdzialanie funkcji strcat"); printf("\n\n Funkcja skleja lancuch0 z kopia_n");
10 printf ("\n\n Przed sklejeniem kopia_n=%s lancuch0=%s",kopia_n, lancuch0) ; strcat(kopia_n, lancuch0 ); printf ("\n\n Po sklejeniu kopia_n=%s", kopia_n) ; printf("\n\n\tdzialanie funkcji strcmp"); printf("\n\n Funkcja porownuje leksykograficznie dwa lancuchy"); printf("\n\n wsk1=%s wsk2= %s",wsk1, wsk2); w = strcmp(wsk2, wsk1); if (w > 0) printf("\n\n wsk2 > wsk1"); if (w==0) printf ("\n\n wsk2 = wsk1") ; if (w < 0) printf("\n\n wsk2 < wsk1"); printf ("\n\n\tdzialanie funkcji strncmp dla 5 znakow"); printf ("\n\n Funkcja porownuje pierwsze 5 znakow swoich argumentow"); printf("\n \n wsk1 = %s wsk2 = %s",wsk1,wsk2); w = strncmp(wsk2, wsk1, 5); if (w > 0) printf("\n wsk2 > wsk1"); if (w==0) printf ("\n wsk2 = wsk1") ; if (w < 0) printf("\n wsk2 < wsk1"); printf("\n\n\tdzialanie funkcji strchr"); printf("\n\n Funkcja wyszukuje zadany znak w tablicy znakow"); wskaznik = strchr(wsk1, znak);
11 printf("\n\n Znak %c jest w %s na pozycji: %d", znak, wsk1, wskaznik - wsk1+1); printf ("\n\n\tdzialanie funkcji strspn"); printf("\n\n Wywolanie ilosc=strspn (string1,string2)"); printf("\n Funkcja wyznacza ilosc poczatkowych znakow ze lancucha string1"); printf("\n ktore wystepuja w lancuchu string2" ); printf("\n\n Lancuch1=%s Lancuch2-%s ", string1,string2); ilosc = strspn(string1, string2); printf("\n\n I1osc poczatkowych znakow z lancucha2 w lancuchu 1 to %d", ilosc); printf( "\n\n\tdzialanie funkcji strpbrk "); printf("\n\n Funkcja poszukuje w jednym lancuchu pierwszego wystapienia"); printf("\n znaku z drugiego lancucha"); printf("\n\n Lancuch1=%s Lancuch2=%s ", lancuch0,lancuch2); wskaznik =(char *) strpbrk(lancuch0,lancuch2); printf ("\n\n Pierwsze wystapienie znaku na pozycji %d", wskaznik-lancuch0); printf ("\n\n\tdzialanie funkcji strstr "); wskaznik = strstr(lancuch1,lancuch3); printf("\n\n Pierwsze wystapienie tekstu =%s", wskaznik); printf("\n\n\tdzialanie funkcji strlen "); dl = strlen(lancuch1); printf ("\n\n Dlugosc lancucha %d", dl);
12 printf("\n\n\tdzialanie funkcji strerror \n\n"); errno=enofile ; bufor = strerror(errno); printf("\n Komunikat bledu dla nr bledu %d= %s", errno,bufor); printf("\n\n\tdzialanie funkcji strtok"); printf("\n\n Wyszukuje w lancuchu1_1 ciagi znakow rozdzielone znakami z lancucha 2_2"); printf("\n lancuch1_1 = %s lancuch2_2 = spacja",lancuch1_1); wskaznik = strtok(lancuch1_1,lancuch2_2); if(wskaznik) printf ("\n Wywolanie nr 0=%s", wskaznik); while(wskaznik) { wskaznik = strtok (NULL," "); printf("\n Wywolanie nr %d=%s",++i,wskaznik); if(i>5) break; } printf("\n\n\tdzialanie funkcji memcpy \n\n"); printf("\n\n Funkcja kopiuje zadana liczbe bajtow z jednej lokalizacji"); printf("\n do drugiej"); memcpy(kopia,lancuch1,strlen(lancuch1+1)); printf("\n\n Skopiowane znaki z tekstu bazowego =%s", kopia); printf ("\n\n\tdzialanie funkcji mmmove \n\n");
13 printf("\n\n Funkcja przenosi (kopiuje) zadana liczbe bajtow z jednej lokalizacji"); printf("\n do drugiej, bloki moga sie pokrywac"); memmove(kopia,lancuch0,strlen(lancuch0)); //bufor = (char *) printf ("\n\n Przeniesione znaki z tekstu bazowego=%s", kopia); printf ("\n\n\tdzialanie funkcji memcmp ") ; printf("\n\n Funkcja porownuje zadana liczbe bajtow z dwoch lokalizacji"); printf("\n wsk1 = %s wsk2 = %s",wsk1,wsk2); w = memcmp(wsk2, wsk1,strlen(wsk2)); if (w > 0) printf("\n wsk2 > wsk1"); if (w==0) printf ("\n wsk2 = wsk1") ; if (w < 0) printf("\n wsk2 < wsk1"); printf ("\n\n\tdzialanie funkcji memchr"); printf("\n\n Funkcja poszukuje zadanego znaku w bloku pamieci"); printf("\n zwraca wskaznik do pierwszego wystapienia znaku"); bufor = (char *)memchr(lancuch3_3,znak,strlen(lancuch3_3)); printf ("\n\n Znak %c wystepuje w tekscie bazowym %s na pozycji o indeksie=%d",znak, lancuch3_3,bufor-lancuch3_3); printf("\n\n\tdzialanie funkcji memset "); printf("\n\n Funkcja nadaje n pierwszym znakom bloku pamieci zadana wartosc "); printf ("\n\n Lancuch przed wstawieniem=%s", lancuch3_3);
14 bufor = (char *)memset( (char *)lancuch3_3,znak,strlen(lancuch3_3)-1); printf ("\n\n Lancuch po wstawieniu=%s", bufor); return 0;}
Ćwiczenie nr 6. Poprawne deklaracje takich zmiennych tekstowych mogą wyglądać tak:
Ćwiczenie nr 6 Temat: Operacje na łańcuchach znaków. Zagadnienia: Zasady pracy z łańcuchami tekstowymi (tablice wartości typu char). funkcje standardowe operacji na łańcuchach, funkcje I/O dla operacji
Katedra Elektrotechniki Teoretycznej i Informatyki. wykład 7- sem.iii. M. Czyżak
Katedra Elektrotechniki Teoretycznej i Informatyki wykład 7- sem.iii M. Czyżak Język C tablice znaków Tablice znaków (łańcuchy) Tablice znaków stanowią specjalny rodzaj tablic o budowie ułatwiającej przetwarzanie
Katedra Elektrotechniki Teoretycznej i Informatyki. wykład 9 - sem.iii. Dr inż. M. Czyżak
Katedra Elektrotechniki Teoretycznej i Informatyki wykład 9 - sem.iii Dr inż. M. Czyżak Język ANSI C tablice znaków Tablice znaków (łańcuchy) Tablice znaków stanowią specjalny rodzaj tablic o budowie ułatwiającej
DANE TEKSTOWE W JĘZYKU C/C++ - TABLICE ZNAKOWE
DANE TEKSTOWE W JĘZYKU C/C++ - TABLICE ZNAKOWE Stała tekstowa / łańcuchowa jest tablicą znaków zakończoną znakiem o kodzie: 0 np. stała łańcuchowa: Jestem tekstem ASCII... J e s t e m t e k s t e m \0...
ŁAŃCUCHY W JĘZYKU C/C++
ŁAŃCUCHY W JĘZYKU C/C++ Stała tekstowa / łańcuchowa jest tablicą znaków zakończoną znakiem o kodzie: 0 np. stała łańcuchowa: Jestem tekstem... 74 101 115 116 101 109 32 116 101 107 115 116 101 109 0......
Operacje na łańcuchach znaków
Operacje na łańcuchach znaków wer. 6 z drobnymi modyfikacjami Wojciech Myszka 2014-02-09 16:32:23 +0100 Łańcuch znaków 1. Z łańcuchów znaków korzystamy powszechnie. 2. Najprostszy przykład: p r i n t f
Programowanie Proceduralne
Programowanie Proceduralne Bożena Woźna-Szcześniak bwozna@gmail.com Jan Długosz University, Poland Wykład 7 strlen size_t strlen(char const *s); Oblicza długość napisu wskazywanego przez s Przykładowy
Podstawy programowania 1
Podstawy programowania 1 Krzysztof Grudzień kgrudzi@kis.p.lodz.pl Wykład nr 2 1 Plan spotkań Wskaźniki Tablice jednowymiarowe & wska źniki. Programowanie w C. Wikibooks 2 Co to jest wskaźnik?? Wskaźnik
Tablice deklaracja, reprezentacja wewnętrzna
Tablice deklaracja, reprezentacja wewnętrzna Tablica jest zmienną złożoną z elementów tego samego typu. Obejmuje ona ciągły obszar pamięci operacyjnej dokładnie tak duży, aby zmieścić wszystkie jej elementy.
Laboratorium 6: Ciągi znaków. mgr inż. Leszek Ciopiński dr inż. Arkadiusz Chrobot dr inż. Grzegorz Łukawski
Laboratorium 6: Ciągi znaków mgr inż. Leszek Ciopiński dr inż. Arkadiusz Chrobot dr inż. Grzegorz Łukawski 17 listopada 2016 1. Wprowadzenie Instrukcja poświęcona jest zmiennym, które służą do przechowywania
Wyklad 7 Funkcje (c.d.). Tablice jednowymiarowe znaków
Wyklad 7 Funkcje (c.d.). Tablice jednowymiarowe znaków Nie wolno definicji funkcji zagniezdzac w ciele innej funkcji! Funkcje bez parametrów musza korzystac ze zmiennych globalnych, jesli zachodzi potrzeba
Wstęp do programowania INP001213Wcl rok akademicki 2017/18 semestr zimowy. Wykład 12. Karol Tarnowski A-1 p.
Wstęp do programowania INP001213Wcl rok akademicki 2017/18 semestr zimowy Wykład 12 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji (1) Obsługa łańcuchów znakowych getchar(), putchar()
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część siódma Przetwarzanie tablic znaków Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera skrót treści wykładu,
Języki programowania. Przetwarzanie tablic znaków. Część druga. Autorzy Tomasz Xięski Roman Simiński
Języki programowania Część druga Przetwarzanie tablic znaków Autorzy Tomasz Xięski Roman Simiński Niniejsze opracowanie zawiera skrót treści wykładu, lektura tych materiałów nie zastąpi uważnego w nim
Języki programowania obiektowego Nieobiektowe elementy języka C++
Języki programowania obiektowego Nieobiektowe elementy języka C++ Roman Simiński roman.siminski@us.edu.pl www.programowanie.siminskionline.pl Przetwarzanie tablic znaków Łańcuchy znakowe jako tablice znaków
Podstawy programowania
Podstawy programowania Część siódma Przetwarzanie tablic znaków Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.programowanie.siminskionline.pl Niniejsze opracowanie zawiera skrót treści wykładu,
Programowanie w C Typ wskaźnikowy do typu znakowego i operacje na łańcuchach
Programowanie w C Typ wskaźnikowy do typu znakowego i operacje na łańcuchach Artur Opaliński (pokój E112) e-mail: (p. wykład administracyjny) URL: (p. wykład administracyjny) Treść wykładu Podstawowe funkcje
main( ) main( void ) main( int argc, char argv[ ] ) int MAX ( int liczba_1, liczba_2, liczba_3 ) źle!
Funkcja wysoce niezależny blok definicji i instrukcji programu (podprogram) Każdy program napisany w języku C/C++ zawiera przynajmniej jedną funkcję o predefiniowanej nazwie: main( ). Najczęściej wykorzystuje
int tab[5]; tab[1]; ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu macierz [ ] - dwuargumentowy operator indeksowania
Rok akademicki 2013/2014, Pracownia nr 10 2/20 Informatyka 1 Tablica elementów ciągły obszar pamięci, w którym umieszczone są elementy tego samego typu Politechnika Białostocka - Wydział Elektryczny Elektrotechnika,
Wprowadzenie do programowania w języku C
Wprowadzenie do programowania w języku C Część piąta Tablice koncepcja, reprezentacja, przetwarzanie Autor Roman Simiński Kontakt siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera
Obsługa plików. Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Laboratorium Podstaw Informatyki Strona 1. Kraków 2013
Laboratorium Podstaw Informatyki Strona 1 Laboratorium Podstaw Informatyki Kierunek Elektrotechnika Obsługa plików Kraków 2013 Laboratorium Podstaw Informatyki Strona 2 Obsługa plików Zanim będziemy mogli
Spis treści JĘZYK C - ŁAŃCUCHY ZNAKÓW. Informatyka 2. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF22
Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 2 Kod przedmiotu: ES1D300 017 (studia stacjonarne)
Spis treści JĘZYK C - ŁAŃCUCHY ZNAKÓW. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu. Numer ćwiczenia INF10Z
Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: EZ1C200 010 (studia niestacjonarne)
Stałe, znaki, łańcuchy znaków, wejście i wyjście sformatowane
Stałe, znaki, łańcuchy znaków, wejście i wyjście sformatowane Stałe Oprócz zmiennych w programie mamy też stałe, które jak sama nazwa mówi, zachowują swoją wartość przez cały czas działania programu. Można
Programowanie proceduralne INP001210WL rok akademicki 2018/19 semestr letni. Wykład 6. Karol Tarnowski A-1 p.
Programowanie proceduralne INP001210WL rok akademicki 2018/19 semestr letni Wykład 6 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Wskaźnik do pliku Dostęp do pliku: zapis, odczyt,
dr inż. Jarosław Forenc
Informatyka 2 Politechnika Białostocka - Wydział Elektryczny Elektrotechnika, semestr III, studia niestacjonarne I stopnia Rok akademicki 2011/2012 Pracownia nr 9 (20.01.2012) dr inż. Jarosław Forenc Rok
Ćwiczenie 4. Obsługa plików. Laboratorium Podstaw Informatyki. Kierunek Elektrotechnika. Laboratorium Podstaw Informatyki Strona 1.
Laboratorium Podstaw Informatyki Strona 1 Laboratorium Podstaw Informatyki Kierunek Elektrotechnika Ćwiczenie 4 Obsługa plików Kraków 2010 Laboratorium Podstaw Informatyki Strona 2 Obsługa plików Zanim
Podstawy Programowania
Podstawy Programowania dr Elżbieta Gawrońska gawronska@icis.pcz.pl Instytut Informatyki Teoretycznej i Stosowanej dr Elżbieta Gawrońska (ICIS) Podstawy Programowania 05 1 / 15 Plan wykładu 1 Biblioteka
Stałe i zmienne znakowe. Stała znakowa: znak
Stałe i zmienne znakowe. Stała znakowa: znak Na przykład: a, 1, 0 c Każdy znak jest reprezentowany w pamięci przez swój kod. Kody alfanumerycznych znaków ASCII to liczby z przedziału [32, 127]. Liczby
Funkcje zawarte w bibliotece < io.h >
PLIKOWE OPERACJE WEJŚCIA - WYJŚCIA Język C/C++ nie ma wbudowanych żadnych instrukcji umożliwiających wykonywanie operacji wejścia-wyjścia! Służą do tego funkcje biblioteczne. Funkcje zawarte w bibliotece
Pliki. Informacje ogólne. Obsługa plików w języku C
Pliki Informacje ogólne Plik jest pewnym zbiorem danych, zapisanym w systemie plików na nośniku danych (np. dysku twardym, pendrive, płycie DVD itp.). Może posiadać określone atrybuty, a odwołanie do niego
. Podstawy Programowania 1. Łańcuchy znaków. Arkadiusz Chrobot. 25 listopada 2015
.. Podstawy Programowania 1 Łańcuchy znaków Arkadiusz Chrobot Zakład Informatyki 25 listopada 2015 1 / 47 Plan.1 Operacje na pojedynczych znakach.2 Typ danych dla ciągów znaków.3 Inicjacja łańcuchów.4
Laboratorium 3: Tablice, tablice znaków i funkcje operujące na ciągach znaków. dr inż. Arkadiusz Chrobot dr inż. Grzegorz Łukawski
Laboratorium 3: Tablice, tablice znaków i funkcje operujące na ciągach znaków dr inż. Arkadiusz Chrobot dr inż. Grzegorz Łukawski 7 kwietnia 2014 1. Wprowadzenie Pierwsza część instrukcji zawiera informacje
Funkcje zawarte w bibliotece < io.h >
PLIKOWE OPERACJE WEJŚCIA - WYJŚCIA Język C/C++ nie ma wbudowanych żadnych instrukcji umożliwiających wykonywanie operacji wejścia-wyjścia! Służą do tego funkcje biblioteczne. Funkcje zawarte w bibliotece
Tablice, funkcje - wprowadzenie
Tablice, funkcje - wprowadzenie Przemysław Gawroński D-10, p. 234 Wykład 5 25 marca 2019 (Wykład 5) Tablice, funkcje - wprowadzenie 25 marca 2019 1 / 12 Outline 1 Tablice jednowymiarowe 2 Funkcje (Wykład
Podstawy programowania. Wykład: 9. Łańcuchy znaków. dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD
Podstawy programowania Wykład: 9 Łańcuchy znaków 1 dr Artur Bartoszewski -Podstawy programowania, sem 1 - WYKŁAD Tablica znaków w językach C i C++ (oraz pochodnych) łańcuch znaków przechowywany jest jako
OPERACJE WEJŚCIA / WYJŚCIA. wysyła sformatowane dane do standardowego strumienia wyjściowego (stdout)
OPERACJE WEJŚCIA / WYJŚCIA Funkcja: printf() biblioteka: wysyła sformatowane dane do standardowego strumienia wyjściowego (stdout) int printf ( tekst_sterujący, argument_1, argument_2,... ) ;
Pliki w C/C++ Przykłady na podstawie materiałów dr T. Jeleniewskiego
Pliki w C/C++ Przykłady na podstawie materiałów dr T. Jeleniewskiego 1 /24 Pisanie pojedynczych znaków z klawiatury do pliku #include void main(void) { FILE *fptr; // wkaznik do pliku, tzw. uchwyt
Pliki. Informacje ogólne. Obsługa plików w języku C
Pliki Informacje ogólne Plik jest pewnym zbiorem danych, zapisanym w systemie plików na nośniku danych. Może posiadać określone atrybuty, a odwołanie do niego odbywa się poprzez nazwę. Każdy plik ma skończoną
Tablice wielowymiarowe. Przykład tablica 2-wymiarowa. Przykład. Przykład 3-wymiarowy. Tak naprawdę nie istnieją w C! Rozważmy tablicę o rozmiarze 3x2
Tablice wielowymiarowe Przykład tablica 2-wymiarowa Tak naprawdę nie istnieją w C! Tak naprawdę C i Java dopuszczają tworzenie tablic tablic tablica 2-wymiarowa = tablica (zwykłych) tablic tablica 3-wymiarowa
1. Wprowadzanie danych z klawiatury funkcja scanf
1. Wprowadzanie danych z klawiatury funkcja scanf Deklaracja int scanf ( const char *format, wskaźnik, wskaźnik,... ) ; Biblioteka Działanie stdio.h Funkcja scanf wczytuje kolejne pola (ciągi znaków),
Wstęp do wskaźników w języku ANSI C
Wstęp do wskaźników w języku ANSI C / Materiał dydaktyczny pomocniczy do przedmiotu Informatyka sem.iii kier. Elektrotechnika/ 1. Wprowadzenie W języku ANSI C dla każdego typu X (wbudowanego, pochodnego,
INFORMATYKA Studia Niestacjonarne Elektrotechnika
INFORMATYKA Studia Niestacjonarne Elektrotechnika Wydział Elektrotechniki i Informatyki dr inż. Michał Łanczont Wydział Elektrotechniki i Informatyki p. E419 tel. 81-538-42-93 m.lanczont@pollub.pl http://lanczont.pollub.pl
Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy. Laboratorium 2. Karol Tarnowski A-1 p.
Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy Laboratorium 2 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Komentarze Funkcja printf() Zmienne Łańcuchy
PODSTAW PROGRAMOWANIA WYKŁAD 7 ŁAŃCUCHY
PODSTAW PROGRAMOWANIA WYKŁAD 7 ŁAŃCUCHY Łańcuch tekstowy w języku c jest pamiętany jako jednowymiarowa tablica znaków zakończona bajtem 0. char * tekst = dzień dobry wszystkim ; char tekst[22]= dzień dobry
2 Przygotował: mgr inż. Maciej Lasota
Laboratorium nr 2 1/7 Język C Instrukcja laboratoryjna Temat: Wprowadzenie do języka C 2 Przygotował: mgr inż. Maciej Lasota 1) Wprowadzenie do języka C. Język C jest językiem programowania ogólnego zastosowania
#include <stdio.h> void main(void) { int x = 10; long y = 20; double s; s = x + y; printf ( %s obliczen %d + %ld = %f, Wynik, x, y, s ); }
OPERACJE WEJŚCIA / WYJŚCIA Funkcja: printf() biblioteka: wysyła sformatowane dane do standardowego strumienia wyjściowego (stdout) int printf ( tekst_sterujący, argument_1, argument_2,... ) ;
iii. b. Deklaracja zmiennej znakowej poprzez podanie znaku
Języki i paradygmaty programowania 1 studia stacjonarne 2018/19 Lab 5. Stałe i zmienne znakowe. Tablice. Wskaźniki do tablic. Operacje na wskaźnikach. Instrukcja switch, case. Wyrażenie przecinkowe. Funkcje
Operacje na plikach. Informatyka. Standardowe strumienie wejścia i wyjścia
Materiały Operacje na plikach Informatyka Operacje wejścia-wyjścia w C/C++: Podejście proceduralne Podejście obiektowe Standardowe strumienie wejścia i wyjścia stdin - strumień wejściowy (klawiatura) cin
Inicjacja tablicy jednowymiarowej
TABLICE C++ Inicjacja tablicy jednowymiarowej typ_komórek_tablicy nazwa_tablicy [ ilość elementów tablicy ] ; np.: int tablica[1000]; czyli tablica, która może przechowywać tysiąc elementów typu całkowitego,
Języki i metodyka programowania. Typy, operatory, wyrażenia. Wejście i wyjście.
Typy, operatory, wyrażenia. Wejście i wyjście. Typy, operatory, wyrażenia Zmienna: [] [ '[' ']' ] ['=' ]; Zmienna to fragment pamięci o określonym
Program wykonujący operację na plikach powinien zachować schemat działania zapewniający poprawną pracę:
Rozdział 1 Obsługa plików W językach C pliki powiązane są ze strumieniami i pracuje się na nich podobnie jak na innych strumieniach. W języku C do operacji na plikach służą funkcje z biblioteki stdio.h,
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część jedenasta Przetwarzanie plików amorficznych Konwencja języka C Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie
۰ Elementem jednostkowym takiego pliku jest bajt. ۰ Format pliku binarnego: [bajty pliku][eof]
1 Plik jest wydzielonym fragmentem pamięci (najczęściej dyskowej) posiadającym nazwę. Z punktu widzenia C plik jest ciągiem bajtów, z których każdy może zostać oddzielnie odczytany. Zgodnie ze standardem
wykład III uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - zarządzanie pamięcią, struktury,
, Programowanie, uzupełnienie notatek: dr Jerzy Białkowski , 1 2 3 4 , Wczytywanie liczb , Wczytywanie liczb 1 #include 2 #include < s t d l i b. h> 3 4 int main ( ) { 5 int rozmiar, numer
Ghost in the machine
Operacje na pami eci i odrobina I/O Zak lad Chemii Teoretycznej UJ 8 stycznia 2007 Funkcje operujace Wstep do operacji I/O na plikach 1 Operacje na pami eci 2 Funkcje operujace 3 Wst Funkcje operujace
Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych.
Temat: Dynamiczne przydzielanie i zwalnianie pamięci. Struktura listy operacje wstawiania, wyszukiwania oraz usuwania danych. 1. Rodzaje pamięci używanej w programach Pamięć komputera, dostępna dla programu,
Programowanie w językach wysokiego poziomu
Programowanie w językach wysokiego poziomu zajęcia nr 2 Elektronika i Telekomunikacja, semestr III rok akademicki 2014/2015 Plan dzisiejszych zajęć Pliki tekstowe 1. Operacje na plikach - wprowadzenie
#include <stdio.h> int main( ) { int x = 10; long y = 20; double s; s = x + y; printf ( %s obliczen %d + %ld = %f, Wynik, x, y, s ); }
OPERACJE WEJŚCIA / WYJŚCIA Funkcja: printf() biblioteka: wysyła sformatowane dane do standardowego strumienia wyjściowego (stdout) int printf ( tekst_sterujący, argument_1, argument_2,... ) ;
Bardzo szybkie podsumowanie: wykład 5
Bardzo szybkie podsumowanie: wykład 5 wer. 7 z drobnymi modyfikacjami! Wojciech Myszka 2016-05-25 11:55:55 +0200 Uwagi 1. Obowiązuje cały materiał! 2. Tu tylko podsumowanie. Formatowane (tekstowe) wejście/wyjście.
Wykład 6. Operacje na łańcuchach znakowych
Wykład 6. Operacje na łańcuchach znakowych 1. Łańcuch znaków jako tablica Do przechowania łańcucha znaków służy tablica znakowa. W kolejnych pozycjach tej tablicy są pamiętane kolejne znaki. Ostatnim znakiem
4. Tablica dwuwymiarowa to jednowymiarowa tablica wskaźników do jednowymiarowych tablic danego typu.
Języki i paradygmaty programowania 1 studia stacjonarne 2018/19 Lab 6. Tablice znakowe o dwóch indeksach, przekazywanie tablic do funkcji cd., dynamiczna alokacja pamięci, funkcje przetwarzające ciągi
wykład II uzupełnienie notatek: dr Jerzy Białkowski Programowanie C/C++ Język C - funkcje, tablice i wskaźniki wykład II dr Jarosław Mederski Spis
i cz. 2 Programowanie uzupełnienie notatek: dr Jerzy Białkowski 1 i cz. 2 2 i cz. 2 3 Funkcje i cz. 2 typ nazwa ( lista-parametrów ) { deklaracje instrukcje } i cz. 2 typ nazwa ( lista-parametrów ) { deklaracje
utworz tworzącą w pamięci dynamicznej tablicę dwuwymiarową liczb rzeczywistych, a następnie zerującą jej wszystkie elementy,
Lista 3 Zestaw I Zadanie 1. Zaprojektować i zaimplementować funkcje: utworz tworzącą w pamięci dynamicznej tablicę dwuwymiarową liczb rzeczywistych, a następnie zerującą jej wszystkie elementy, zapisz
Informatyka 1. Plan dzisiejszych zajęć. zajęcia nr 11. Elektrotechnika, semestr II rok akademicki 2008/2009
Informatyka 1 zajęcia nr 11 Elektrotechnika, semestr II rok akademicki 2008/2009 mgr inż.. Paweł Myszkowski Plan dzisiejszych zajęć 1. Łańcuchy znaków 2. Wprowadzanie i wyprowadzanie znaków w i łańcuchów
Plik jest reprezentowany przez strumień znaków (bajtów) o zmiennej długości. Koniec strumienia identyfikowany jest znacznikiem końca pliku EOF.
Pliki w C++ Plik jest reprezentowany przez strumień znaków (bajtów) o zmiennej długości. Koniec strumienia identyfikowany jest znacznikiem końca pliku EOF. Z każdym strumieniem związany jest wskaźnik bieżącej
Języki programowania. Karolina Mikulska-Rumińska Pokój 573, tel Konsultacje wtorek 9-10.
Języki programowania Karolina Mikulska-Rumińska E-mail: karolamik@fizyka.umk.pl Pokój 573, tel. 3346 Konsultacje wtorek 9-10. Pliki Dwa rodzaje plików: Tekstowe, Binarne Aby otworzyć plik należy najpierw
7 Przygotował: mgr inż. Maciej Lasota
Laboratorium nr 7 1/5 Język C Instrukcja laboratoryjna Temat: Operacje na plikach. 7 Przygotował: mgr inż. Maciej Lasota 1) Pliki. Plik (ang. file), jest to nazwany ciąg danych (inaczej zbiór danych),
Proste typy zmiennych języka C++ *) Zapis 3.4 e-38 jest równoważny zapisowi 3,
WYKŁAD 1. PODSTAWY 1_1. Typy zmiennych Proste typy zmiennych języka C++ Nazwa typu (nazwa skrócona) Rozmiar (bajtów) unsigned char 1 signed char (char) unsigned short int (unsigned) signed short int (int)
Biblioteka standardowa - operacje wejścia/wyjścia
Biblioteka standardowa - operacje wejścia/wyjścia Przemysław Gawroński D-10, p. 234 Wykład 6 15 stycznia 2019 (Wykład 6) Biblioteka standardowa - operacje wejścia/wyjścia 15 stycznia 2019 1 / 14 Outline
Języki programowania. Przetwarzanie plików amorficznych Konwencja języka C. Część siódma. Autorzy Tomasz Xięski Roman Simiński
Języki programowania Część siódma Przetwarzanie plików amorficznych Konwencja języka C Autorzy Tomasz Xięski Roman Simiński Niniejsze opracowanie zawiera skrót treści wykładu, lektura tych materiałów nie
Wykład VI. Programowanie. dr inż. Janusz Słupik. Gliwice, 2014. Wydział Matematyki Stosowanej Politechniki Śląskiej. c Copyright 2014 Janusz Słupik
Wykład VI Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2014 c Copyright 2014 Janusz Słupik Operacje na plikach Operacje na plikach Aby móc korzystać z pliku należy go otworzyć w odpowiednim
PARADYGMATY PROGRAMOWANIA Wykład 3
PARADYGMATY PROGRAMOWANIA Wykład 3 Definiowanie operatorów i ich przeciążanie Przykłady zastosowania operatorów: a) operator podstawienia ( = ) obiektów o złożonej strukturze, b) operatory działania na
Zmienne, stałe i operatory
Zmienne, stałe i operatory Przemysław Gawroński D-10, p. 234 Wykład 2 4 marca 2019 (Wykład 2) Zmienne, stałe i operatory 4 marca 2019 1 / 21 Outline 1 Zmienne 2 Stałe 3 Operatory (Wykład 2) Zmienne, stałe
Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy. Laboratorium 3. Karol Tarnowski A-1 p.
Wstęp do programowania INP003203L rok akademicki 2018/19 semestr zimowy Laboratorium 3 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Dyrektywy preprocesora #include #define Interakcja
Podstawy programowania skrót z wykładów:
Podstawy programowania skrót z wykładów: // komentarz jednowierszowy. /* */ komentarz wielowierszowy. # include dyrektywa preprocesora, załączająca biblioteki (pliki nagłówkowe). using namespace
Języki i metodyka programowania. Wprowadzenie do języka C
Literatura: Brian W. Kernighan, Dennis M. Ritchie Język Ansi C, Wydawnictwa Naukowo - Techniczne, 2007 http://cm.bell-labs.com/cm/cs/cbook/index.html Scott E. Gimpel, Clovis L. Tondo Język Ansi C. Ćwiczenia
Tablice w argumentach funkcji. Tablicy nie są przekazywane po wartości Tablicy są przekazywane przez referencje lub po wskaźniku
Tablice w argumentach funkcji Tablicy nie są przekazywane po wartości Tablicy są przekazywane przez referencje lub po wskaźniku Przykład: char str[] = abcdef ;... fun(str); // argument faktyczny to id
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część dziewiąta Tablice a zmienne wskaźnikowe Wersja skrócona, tylko C++ Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie
scanf( %s,tekst); //znaki podane z klawiatury (do pierwszego białego znaku ) //s kopiowane do zmiennej tekst i dostawiany jest znak \0
Temat: Operacje na łacuchach tablicach znaków 1. Pojcie łacucha Łacuch to cig znaków zakoczony znakiem o kodzie zero ( \0 ). Łacuch moe by zapamitany w programie w stałej albo zmiennej łacuchowej. Przykład
Katedra Elektrotechniki Teoretycznej i Informatyki. wykład 12 - sem.iii. M. Czyżak
Katedra Elektrotechniki Teoretycznej i Informatyki wykład 12 - sem.iii M. Czyżak Język C - preprocesor Preprocesor C i C++ (cpp) jest programem, który przetwarza tekst programu przed przekazaniem go kompilatorowi.
1 Przetwarzanie tablic znakowych
1 Przetwarzanie tablic znakowych Ćwiczenie to poświęcone jest poznaniu i przetrenowaniu metod przetwarzania tablic znakowych. Tablice znakowe w języku C i C++ umożliwiają przetwarzanie napisów. Umiejętność
Argumenty wywołania programu, operacje na plikach
Temat zajęć: Argumenty wywołania programu, operacje na plikach Autor: mgr inż. Sławomir Samolej Zagadnienie 1. (Zmienne statyczne) W języku C można decydować o sposobie przechowywania zmiennych. Decydują
Języki i metody programowania I
Języki i metody programowania I dr inż. Piotr Szwed Katedra Informatyki Stosowanej C2, pok. 403 e-mail: pszwed@agh.edu.pl http://home.agh.edu.pl/~pszwed/ Aktualizacja: 2013-01-18 8. Łańcuchy znaków Łańcuchy
Wskaźniki do funkcji. Wykład 11. Podstawy programowania ( język C ) Wskaźniki do funkcji (1) Wskaźniki do funkcji (2)
Podstawy programowania ( język C ) Wskaźniki do funkcji Wykład 11. Tomasz Marks - Wydział MiNI PW -1- Tomasz Marks - Wydział MiNI PW -2- Wskaźniki do funkcji (1) W języku C funkcje nie są zmiennymi, ale
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część jedenasta Reprezentacja i przetwarzanie plików Konwencja języka C Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie
Podstawy programowania. Wykład Funkcje. Krzysztof Banaś Podstawy programowania 1
Podstawy programowania. Wykład Funkcje Krzysztof Banaś Podstawy programowania 1 Programowanie proceduralne Pojęcie procedury (funkcji) programowanie proceduralne realizacja określonego zadania specyfikacja
Wstęp do programowania
wykład 8 Agata Półrola Wydział Matematyki i Informatyki UŁ sem. zimowy 2016/2017 Tablice wielowymiarowe inaczej Efekt tablicy wielowymiarowej można uzyskać definiując tablicę jednowymiarową odpowiedniego
ISO/ANSI C - funkcje. Funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje. ISO/ANSI C - funkcje
Funkcje (podprogramy) Mianem funkcji określa się fragment kodu, który może być wykonywany wielokrotnie z różnych miejsc programu. Ogólny zapis: typ nazwa(argumenty) ciało funkcji typ określa typ danych
Powyższe wyrażenie alokuje 200 lub 400 w zależności od rozmiaru int w danym systemie. Wskaźnik wskazuje na adres pierwszego bajtu pamięci.
1. Tablice dynamiczne Początkowa zadeklarowana wielkość tablicy czasami może okazać niewystarczająca, lub nadmierna. Dynamiczna alokacja pamięci wykorzystywana jest w celu otrzymania bądź zwolnienia pamięci
WYKŁAD 10. Zmienne o złożonej budowie Statyczne i dynamiczne struktury danych: lista, kolejka, stos, drzewo. Programy: c5_1.c, c5_2, c5_3, c5_4, c5_5
WYKŁAD 10 Zmienne o złożonej budowie Statyczne i dynamiczne struktury danych: lista, kolejka, stos, drzewo Programy: c5_1.c, c5_2, c5_3, c5_4, c5_5 Tomasz Zieliński ZMIENNE O ZŁOŻONEJ BUDOWIE (1) Zmienne
Uzupełnienie dot. przekazywania argumentów
Uzupełnienie dot. przekazywania argumentów #include #include struct nowa { int f; char line[20000]; int k; } reprezentant; int main() { void funkcja7( struct nowa x); reprezentant.k=17;
Programowanie w C++ Wykład 5. Katarzyna Grzelak. 26 marca kwietnia K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40
Programowanie w C++ Wykład 5 Katarzyna Grzelak 26 marca 2018 9 kwietnia 2018 K.Grzelak (Wykład 1) Programowanie w C++ 1 / 40 Pojęcia z poprzedniego wykładu Podział programu na funkcje podział na niezależne
Reprezentacja symboli w komputerze. Znaki alfabetu i łańcuchy znakowe. Programowanie Proceduralne 1
Reprezentacja symboli w komputerze. Znaki alfabetu i łańcuchy znakowe. Programowanie Proceduralne 1 ASCII The American Standard Code for Information Interchange, 1968 r. 7 bitów, liczby z zakresu 0-127
Podstawy programowania w języku C++
Podstawy programowania w języku C++ Część dziesiąta Rekordy w C/C++ struktury Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.programowanie.siminskionline.pl Niniejsze opracowanie zawiera skrót
Spis treści JĘZYK C - TABLICE JEDNOWYMIAROWE, ŁAŃCUCHY ZNAKÓW. Informatyka 1. Instrukcja do pracowni specjalistycznej z przedmiotu
Politechnika Białostocka Wydział Elektryczny Katedra Elektrotechniki Teoretycznej i Metrologii Instrukcja do pracowni specjalistycznej z przedmiotu Informatyka 1 Kod przedmiotu: ES1C200 009 (studia stacjonarne)
Laboratorium 1. Programowanie II - Kierunek Informatyka. dr inż. Janusz Słupik. Gliwice, 2015. Wydział Matematyki Stosowanej Politechniki Śląskiej
Laboratorium 1 - Kierunek Informatyka Wydział Matematyki Stosowanej Politechniki Śląskiej Gliwice, 2015 c Copyright 2015 Janusz Słupik Punkty Na laboratorium można zdobyć 60 punktów. Ocena ogólna z zajęć:
MATERIAŁY POMOCNICZE PODSTAWY PROGRAMOWANIA Na podstawie: Programowanie w C - Stworzone na Wikibooks, bibliotece wolny podręczników
MATERIAŁY POMOCNICZE PODSTAWY PROGRAMOWANIA Na podstawie: Programowanie w C - Stworzone na Wikibooks, bibliotece wolny podręczników Funkcja getchar() Jest to bardzo prosta funkcja, wczytująca 1 znak z
Operacje wejścia/wyjścia odsłona pierwsza
Bogdan Kreczmer ZPCiR IIAiR PWr pokój 307 budynek C3 bogdan.kreczmer@pwr.wroc.pl Copyright c 2005 2008 Bogdan Kreczmer Niniejszy dokument zawiera materiały do wykładu na temat programowania obiektowego.
Wykład II Tablice (wstęp) Przykłady algorytmów Wstęp do języka C/C++
Podstawy programowania Wykład II Tablice (wstęp) Przykłady algorytmów Wstęp do języka C/C++ 1 dr Artur Bartoszewski - Podstawy programowania, sem. 1- WYKŁAD Część I Wstęp do struktur danych: Tablice 2