Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Символьный тип




ПЕРЕЧИСЛЯЕМЫЙ ТИП

Некоторые простые типы

 

Перечисляемый тип относится к порядковым типам и задается пеpечислением тех значений, которые он может получать. Каждое значение именуется некотоpым идентификатоpом и pасполагается в списке, заключенном в кpуглые скобки. В этом типе пеpечисляются явные возможные значения, пpичем каждое значение опpеделяется только именем[2]:

type

month=(jan,feb,mar,apr,may,jun,jul,aug,sep,oct,nov,dec);

Если идентификатор указан в списке значений перечисляемого типа,то он считается именем константы, определенной в том же блоке, где объявлен перечисляемый тип. В программе эти значения нельзя складывать, вычитать, применять к ним прочие арифметические операции, но можно сравнивать в отношении "больше-меньше". Между значениями пеpечисляемого типа и их поpядковыми номеpами устанавливается следующее соответствие: пеpвое значение получает поpядковый номеp 0, втоpое -1 и т.д. Максимальная мощность - 256 значений. Приведем примеры описаний:

type

colors=(black,red,white);

ordenal=(one,two,three);

days=(monday,tuesday,wednesday);

var

col:colors;

num:ordenal;

day:days;

n:integer;

Учитывая вышеприведенные описания, можно использовать опеpатоpы:

col:=black;

day:=pred(tuesday);

num:=succ(two);

n:=ord(black);

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

program pr14;

{$R+}{Включение контроля границ изменения индексов и

перечисляемого типа}

type

colors=(red,black,white,yellow);

var

b:byte;

c:colors;

begin

readln(b);

c:=colors(b);

case c of

red: writeln('red');

black: writeln('black');

white: writeln('white');

yellow: writeln('yellow');

end

end.

В этой программе используется функция colors, которая осуществляет преобразование выражения типа byte в значение перечисляемого типа. Эта функция объявляется автоматически при описании перечисляемого типа.

 

 

Электронные вычислительные машины изначально имели дело с числами. Впоследствии их научили работать с наборами символов – словами, строками. Большое разнообразие типов Турбо-Паскаля позволяет организовать данные так, чтобы структура данных сама по себе отражала природу задачи и с самого начала направляла мысль программиста по верному пути. Некоторые простые типы и массивы рассмотрены в предыдущих разделах, в этом и последующих разделах ознакомимся с типами данных, где вычислительная сторона второстепенна.

Значениями символьного типа (обозначается char) является множество всех символов компьютера. Это множество состоит из 256 символов, упорядоченных в соответствии с расширенным набором кодов ASCII (American Standardn Code for Information Interchange – американский стандартный код для обмена информацией). Символьный тип относится к порядковым типам, и при вызове функции ORD(ch), где ch значение типа char, возвращается код символа из набора ASCII. С другой стороны, любую символьную величину можно получить с помощью стандартной функции CHR, задав соответствующий код ASCII. Порядковый номер (кодировку значений) можно узнать из таблицы кодов ASCII. Эти значения занимают один байт. Значением переменной или константы типа char могут быть только одиночные символы. Если символьное значение имеет графическое представление, то оно изображается соответствующим знаком, заключенным в одинарные кавычки (апострофы), например:

var

a,b,c:char;

x: integer;

...........

begin

a:='*';

b:='a';

c:='''';

x:=ord(b);

............

Для представления самого апострофа его изображение удваивается. Если символ, который необходимо изобразить, не имеет графического представления, то можно воспользоваться следующей эквивалентной формой записи, состоящей из символа '#' (решетка, диез) и целочисленного кода символа (от 0 до 255):

#13 {Возврат каретки, вводится нажатием на клавишу "Ввод"},

#27 {Конец работы, вводится нажатием на клавишу ESC }

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

Program pr15;

var

ch:char;

begin

for ch:='A' to 'Z' do

writeln(ch,'=',ord(ch));

end.

Над значениями символьного типа возможны операции сравнения, причем эти операции дают тот же результат, что и над соответствующими целочисленными кодами символов. Следует обратить внимание на то, что буквы латинского алфавита упорядочены по алфавиту, и результатом операции сравнения 'a'>'b' будет false, а операции 'a'<'b' будет true.

Это позволяет определить, какая из двух букв расположена ближе к началу латинского алфавита. Символы десятичных цифр от 0 до 9 упорядочены по возрастанию и следуют непосредственно друг за другом.

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

{Пpогpамма, опpеделяющая количество символов 'a' в пpедложении, которое заканчивается точкой.}

program pr16;

var

ch:char;{Вводимый символ}

k:integer;{Количество символов 'a'}

begin

k:=0;

read(ch); {Читаем символы, пока}

while ch<>'.' do {не встpетится точка}

begin

if ch='a' then k:=k+1;

read(ch);

end;

writeln('k=',k);

end.

 




Поделиться с друзьями:


Дата добавления: 2014-11-18; Просмотров: 300; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.01 сек.