Язык Си - руководство для начинающих
Шрифт:
ЧТО ВЫ ДОЛЖНЫ БЫЛИ УЗНАТЬ В ЭТОЙ ГЛАВЕ
Как объявить строку символов: static char fun[ ] и т. д.
Как инициализировать строку символов: static char *p0 = "0!"
Как использовать gets и puts
Как использовать strlen, strcmp, strcpy и strcatf
Как использовать аргументы командной строки.
В чем сходство и различие описателей char *bliss и char bliss[ ]
Как создать строковую константу: "используя кавычки".
ВОПРОСЫ
Вопросы
1. Что неправильно в этой попытке описания символьной строки?
main {
char name[ ] = {'F', 'с', 's', 's'};
2. Что напечатает эта программа?
#include <stdio.h>
main
{
static char note[ ] = "До встречи в буфете." ;
char *ptr;
ptr = note;
puts(ptr);
puts(++ptr);
note[7] = '\0';
puts(note);
puts(++ptr);
}
3. Что напечатает эта программа?
main
{ static char food[ ] = "Йумми";
char *ptr;
ptr = food + strlen(food);
while(--ptr >= food) puts(ptr);
}
4. Что напечатает нижеследующая программа?
main
{
static char goldwyn[28] = " аз я считываю"
static char samuel[40] = " Каждый р" ;
char *quote = " часть строки."
strcat(goldwyn, quote);
strcat(samuel, goldwyn);
puts(samuel);
}
5. Создайте функцию, которая использует указатель строки в качестве аргумента и возвращает указатель, ссылающийся на первый пробел в строке в указанном месте или после него. Если она не находит ни одного пробела, то пусть возвращает NULL– указатель.
Ответы
1. Класс памяти должен быть extern или static; инициализация должна включать символ '\0'.
2.
До встречи в буфете.
о встречи в буфете.
До вст
вст
3.
и
ми
мми
умми
Йумми
4.
Каждый раз я считываю часть строки.
5.
char *strblk(string)
char *string; {
while(*string != ' ' && *string != '\0')
string++; /*
if(*string == '\0')
return(NULL); /* NULL = 0 */
else return(string); }
УПРАЖНЕНИЯ
1. Создайте функцию, которая считывает очередные n символов при вводе, включая символы пробелов, табуляции и новой строки.
2. Модифицируйте последнюю функцию таким образом, чтобы она останавливалась после ввода n символов или после первого символа пробела, табуляции или но вой строки независимо от того, какой из них идет первым [только не используйте функцию scanf].
3. Создайте функцию, которая считывает очередное слово при вводе; определите слово как последовательность символов, не включающую символы пробела, табуляции или новой строки.
4. Создайте функцию, которая ищет первое появление определенного символа в определенной строке. Функция должна возвращать указатель, ссылающийся на этот символ, в случае успешного поиска или NULL, если символ в строке не найден.
14. Структуры и другие типы данных
СТРУКТУРЫ ДАННЫХ
СТРУКТУРНЫЕ ШАБЛОНЫ, ТЕГИ И ПЕРЕМЕННЫЕ
ДОСТУПНЫЕ ЧАСТИ СТРУКТУРЫ
СТРУКТУРНЫЕ УКАЗАТЕЛИ
СТРУКТУРНЫЕ МАССИВЫ
ФУНКЦИИ И СТРУКТУРЫ
ОБЪЕДИНЕНИЯ
СОЗДАНИЕ НОВЫХ ТИПОВ
КЛЮЧЕВЫЕ СЛОВА struct, union, typedef
ОПЕРАЦИИ – >
Успех программы часто зависит от удачного выбора способа представления данных, с которыми она должна работать. В этом отношении языку Си очень повезло (и не случайно), так как он обладает очень мощными средствами представления сложных данных. Этот тип данных, называемых "структурой", не только достаточно гибок для представления разнообразных данных, но, кроме того, он позволяет пользователю создавать новые типы. Если вы знакомы с "записями" языка Паскаль, вам должны быть удобны структуры.
Посмотрим на конкретном примере, почему структуры нам необходимы и как их создавать и использовать.
ТИПОВАЯ ЗАДАЧА: ИНВЕНТАРИЗАЦИЯ КНИГ
Гвен Гленн хочет напечатать опись своих книг. Она хотела бы занести в нее различную информацию о каждой книге: ее название, фамилию автора, издательство, год издания, число страниц, тираж и цену. Теперь некоторые из этих элементов, такие, как название, можно записать в массив строк. Другие элементы требуют массив целого типа или массив типа float. Если работать с семью различными массивами и следить за веси содержащейся в них информацией, можно сойти с ума, особенно если Гвен желает иметь несколько списков - список, упорядоченный по названиям, список, упорядоченный по авторам, по цене и т. д. Гораздо лучше было бы использовать один массив, в котором каждый элемент содержал бы всю информацию о книге.