int с, i, nwhite, nother;
int ndigit[10];
nwhite = nother = 0;
for (i = 0; i ‹ 10, ++i)
ndigit[i]= 0;
while ((c = getchar)!= EOF)
if (c ›='0' && с ‹= '9')
++ndigit[c - '0'];
else if (c == ' ' || c == '\n' || c == '\t')
++nwhite;
else
++nother;
printf("цифры =");
for (i = 0; i ‹ 10; ++i)
printf("%d", ndigit[i]);
printf(", символы-разделители =%d, прочие =%d\n", nwhite, nother);
}
В результате выполнения этой программы будет напечатан следующий результат:
цифры = 9 3 0 0 0 0 0 0 0 1, символы-разделители = 123, прочие = 345
Объявление
int ndigit[10];
объявляет
Индексом может быть любое целое выражение, образуемое целыми переменными (например
Приведенная программа опирается на определенные свойства кодировки цифр. Например, проверка
if (c ›= '0' && c ‹= '9') …
определяет, является ли находящийся в
c -'0'
есть числовое значение цифры. Сказанное справедливо только в том случае, если для ряда значений '0','1',…, '9' каждое следующее значение на 1 больше предыдущего. К счастью, это правило соблюдается во всех наборах символов.
По определению, значения типа
Следующий фрагмент определяет, является символ цифрой, символом-разделителем или чем-нибудь иным.
if (c ›= '0' && c ‹= '9')
++n[c-'0'];
else if (c ==' ' || c == '\n' || c == '\t')
++nwhite;
else
++nother;
Конструкция вида
if (
else if (
:
:
else
часто применяется для выбора одного из нескольких альтернативных путей, имеющихся в программе.
else if (
Когда их несколько, программу разумно форматировать так, как мы здесь показали. Если же каждый следующий
Инструкция switch, речь о которой пойдет в главе 3, обеспечивает другой способ изображения многопутевого ветвления на языке Си. Он более подходит, в частности, тогда, когда условием перехода служит совпадение значения некоторого выражения целочисленного типа с одной из констант, входящих в заданный набор. Вариант нашей программы, реализованной с помощью switch, приводится в параграфе 3.4.
Упражнение 1.13. Напишите программу, печатающую гистограммы длин вводимых слов. Гистограмму легко рисовать горизонтальными полосами. Рисование вертикальными полосами - более трудная задача.
Упражнение 1.14. Напишите программу, печатающую гистограммы частот встречаемости вводимых символов.
1.7 Функции