Пример: программа для работы с символами

В этом разделе приведен пример программы управления символами.

/*
Эта программа предназначена для демонстрации применения функций
"классификации и преобразования символов". Для получения символов
применяются функции
getchar и putchar из библиотеки stdio
  
Задачи программы:

- Считать ввод из stdin 

- Проверить, что все символы - печатаемые
  символы ascii

- Преобразовать все прописные символы строчные

- Удалить лишние пробелы

- Выдать статистику по типам символов

Эта программа демонстрирует применение следующих
функций: 


- isascii (ctype)

- iscntrl (ctype)

- isspace (ctype)

-
isalnum
(ctype)


- isdigit (ctype)

- isalpha (ctype)

- isupper (ctype)

-
islower
(ctype)


- ispunct (ctype)

- tolower (conv)

- toascii ( conv)

*/
  
#include <stdio.h> /* Обязательный включаемый файл */
#include <ctype.h>  /* Функции для определения типа

символов */
  
/* Различные счетчики для статистики */

int asciicnt, printcnt, punctcnt, uppercnt, lowercnt,  

digcnt, alnumcnt, cntrlcnt, spacecnt, totcnt, nonprntcnt, linecnt, tabcnt ;
  
main()
{
  
int ch ; /* Обрабатываемый символ */
char c , class_conv() ;
  
asciicnt=printcnt=punctcnt=uppercnt=lowercnt=digcnt==0;
cntrlcnt=spacecnt=totcnt=nonprntcnt=linecnt=tabcnt=0;
alnumcnt=0;
 
while ( (ch =getchar()) != EOF )
{
 
totcnt++;
c = class_conv(ch) ;
putchar(c);
 
}
printf("Введено %d\n строк", linecnt);
printf(" Распределение символов по категориям:\n");
printf(" TOTAL  ASCII  CNTRL   PUNCT   ALNUM  DIGITS UPPER

LOWER   SPACE   TABCNT\n");
 
printf("%5d %5d %5d %5d %5d %5d %5d %5d %5d %5d\n",totcnt,

asciicnt, cntrlcnt, punctcnt, alnumcnt, digcnt, uppercnt,lowercnt, spacecnt, tabcnt );
 
}
 
char class_conv(ch)
char ch;
{
 
if (isascii(ch)) {
 
asciicnt++;
if ( iscntrl(ch) && ! isspace(ch)) {
 
nonprntcnt++ ;
cntrlcnt++ ;
return(' ');
 
}
else if ( isalnum(ch)) {
 
alnumcnt++;
if (isdigit(ch)){
digcnt++;
return(ch);
}
else if (isalpha(ch)){
if ( isupper(ch) ){

uppercnt++ ;
return(tolower(ch));
}
else if ( islower(ch) ){
lowercnt++;
return(ch);
}
else {
/*
Невозможная ситуация - символ алфавита должен быть либо
строчным, либо
прописным.
*/ 
fprintf(stderr,"Ошибка классификации %c \n",ch);
return(NULL);
}

}
else if (ispunct(ch) ){
punctcnt++;
return(ch);
}
else if ( isspace(ch) ){
spacecnt++;
if ( ch == '\n' ){
linecnt++;
return(ch);
}
while ( (ch == '\t' ) || ( ch == ' ' ) ) {
if ( ch == '\t' ) tabcnt ++ ;
else if ( ch == ' ' ) spacecnt++ ;
totcnt++;
ch = getchar();
}
ungetc(ch,stdin);
totcnt--;
return(' ');
}
else {
/*
Невозможная ситуация - любой символ ASCII
принадлежит одному из классов.
*/
fprintf(stderr,"Ошибка классификации %c \n",ch);
return (NULL);
}
}
else
{
fprintf(stdout,"Обнаружен не-ASCII символ\n");
return(toascii(ch));
}

}