Главная

Популярная публикация

Научная публикация

Случайная публикация

Обратная связь

ТОР 5 статей:

Методические подходы к анализу финансового состояния предприятия

Проблема периодизации русской литературы ХХ века. Краткая характеристика второй половины ХХ века

Ценовые и неценовые факторы

Характеристика шлифовальных кругов и ее маркировка

Служебные части речи. Предлог. Союз. Частицы

КАТЕГОРИИ:






Листинг 4. Использование двух параллельных массивов.




/*rooms.c*/int room[10] = {102, 107, 109, 112, 115, 116, 123, 125, 127, 130};int max[10] = {12, 43, 23, 12, 20, 15, 16, 23, 12, 15};main() { int index, choice, num, rooms, flag, found; rooms = 10; puts("1. Показать вместимость всех комнат\n"); puts("2. Определить вместимость определенной комнаты\n"); puts("3. Найти комнату определенной вместимости\n"); printf("Введите Ваш выбор от 1 до 3: "); scanf("%d", &choice); if (choice == 1) { for (index = 0; index < rooms; index++) printf("Комната #%d рассчитана на %d мест\n", room[index], max[index]); } if (choice == 2) { printf("введите номер комнаты: "); scanf("%d", &num); index = 1; found = 0; while (! found && index < rooms) if (room[index] == num) found = 1; else index++; if (! found) puts("Комнаты с таким номером нет в списке\n"); else printf("Комната #%d рассчитана на %d мест\n", room[index], max[index]); } if (choice == 3) { flag = 0; printf("Введите минимальное желательное количество мест:"); scanf("%d", &num); for (index = 0; index < rooms; index++) if (max[index] >= num) { flag = 1; printf("Комната #%d рассчитана на %d мест\n", room[index], max[index]); } if (flag == 0) puts("Комнат с таким количеством мест нет\n"); } }

В этой программе максимальное значение индекса массива присваивается переменной rooms, а затем на экран выводится меню. Выбор одного из пунктов меню определяет, какая из функций будет выполняться. Это осуществляется с помощью последовательности из трех инструкций if. Аналогичную программу можно было написать с использованием инструкции switch или вложенных инструкций if...else.

Первая процедура в цикле for выводит список всех комнат и их вместимость. Здесь необходима только одна индексная переменная, которая используется в качестве индекса как для массива room, так и для массива max.

Вторая процедура просматривает массив в поисках элемента, имеющего значение, соответствующее номеру комнаты, введенному пользователем.

В третьей процедуре выполняется поиск номеров комнат, которые могут обеспечить определенную вместимость, указанную пользователем. Но после обнаружения первого подходящего варианта поиск не останавливается. Просмотр массива происходит до конца с целью составления списка всех комнат, удовлетворяющих указанному условию. Переменная flag используется для индикации того, что не обнаружено ни одной подходящей комнаты.

Строки

Строкой называется массив символов. При определении строки вы присваиваете ей имя и указываете максимальное количество символов, которое может в ней содержаться. Однако не забывайте о том, что один элемент массива всегда резервируется для нулевого символа (\0), вследствие чего при определении строки следует указывать количество элементов на единицу больше действительно предполагаемой максимальной длины строки.

Си и Си++ позволяют осуществлять ввод и вывод массива символов в виде некой целостности — строки. В то же время, каждый символ является отдельным независимым элементом массива (рис.7). Например, с помощью следующей программы можно ввести строку, а затем отобразить составляющие ее отдельные символы:

main() { char name[20]; int index; printf("Введите Ваше имя: "); scanf("%s", name); for (index = 0; index < 20; index++) printf("%c\n", name[index]); }


Рис. 7. Каждый из символов, составляющих строку, в действительности является отдельным элементом массива

Если в действительности было введено меньше двадцати символов, элементы массива, следующие за нулевым символом, содержат случайные величины.

Если бы в языке Си отсутствовала функция gets(), то ввод строки можно было осуществить путем последовательного ввода символов и присваивания их в качестве значения отдельным элементам массива, как это продемонстрировано в Листинге 5.






Не нашли, что искали? Воспользуйтесь поиском:

vikidalka.ru - 2015-2024 год. Все права принадлежат их авторам! Нарушение авторских прав | Нарушение персональных данных