69738

Програми друку граничних констант

Домашняя работа

Информатика, кибернетика и программирование

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

Украинкский

2014-10-09

38 KB

0 чел.

Самостійне вивчення

Тема 2: Програми друку граничних констант.

Введених засобів препроцесора і мови цілком достатньо для програми, що виводить на друк (на екран дісплея) значення констант, що визначають в конкретній системі (для конкретного компілятора) межі зміни даних різних типів. Кажучи про іменовані константи, треба відзначити, що серед стандартних заголовочних файлів компілятора завжди є файли limits.h і float.h, що включають препроцесорне визначення граничних констант. Наступна програма друкує деякі із значень граничних констант для цілих типів, визначених конкретною реалізацією компілятора з мови Сі.

#include <stdio.h>

#include <limits.h> /* Визначення граничних цілочисельних констант*/

void main( )

{

printf("\nCHAR_BIT=%d", CHAR_BIT);

printf("\nSCHAR_MIN=%d\t\tSCHAR_MAX=%d",SCHAR_MIN,SCHAR_MAX);

printf("\nUCHAR_MAX=%d", UCHAR_MAX);

printf("\nINT_MIN=%d\t\tINT_MAX=%d", INT_MIN,INT_MAX) ;

printf("\nLONG_MIN=%ld\tLONG_MAX=%ld", LONG_MIN, LONG_MAX);

}

Результат виконання програми з компілятором Turbo С:

CHAR_BIT=8

SCHAR_MIN=-128                          SCHAR_MAX=127

UCHAR_MAX=255

INT_MIN=-32768                          INT_MAX=32767

LONG_MIN=-2147483648             LONG_MAX=2147483647

У викликах функції printf() потрібно звернути увагу на специфікації перетворення. Всі константи цілочисельні, тому використовується специфікатор 'd'. Для величин типу long потрібно модифікатор 'l', тобто константи LONG_MIN і LONG_MAX виводяться з використанням специфікацій перетворення %ld. У всіх специфікаціях перетворення відсутнє зведення про довжину зображення значень, що виводяться. Кількість позицій в зображеннях констант залежить від їх значень. Управляючі послідовності '\n' і '\t' забезпечують при виводі відповідно переходи на нові рядки і табуляцію.

Для виводу дійсних значень з мантисою і порядком в рядку формату функції printf( ) потрібно використати специфікацію %е. Наступна програма виводить на екран значення деяких з граничних дійсних констант:

#include <stdio.h>

#include <float.h> /* Визначення граничних дійсних констант*/

void main( )

{

printf("\nFLT_EPSILON=%e", FLT_EPSILON);

printf<"\nDBL_EPSILON=%e", DBL_EPSILON);

printf("\nFLT_MIN=%e\tFLT_MAX=%e", FLT_MIN, FLT_MAX);

printf("\n \t \t \tDBL_MAX=%e", DBL_MAX);

printf("\nFLT_MANT_DIG=%d", FLT_MANT_DIG);

printf ("\nDBL_MANT_DIG=%d", DBL_MANT__DIG) ;

}

Результати виконання програми з компілятором Turbo C:

FLT_EPSILON=1.192093е-07

DBL_EPSILON=2.22044бе-16

FLT_MIN=1.1754 94e-38             FLT_MAX=3.402823е+38

                                                   DBL_MAX=1.797693е+308

FLT_MANT_DIG=24

DBL_MANT_DIG=53

Надруковані константи FLT_EPSILON і DBL_EPSILON - максимальні значення типів float і double, сума кожного з яких із значенням 1.0 не відрізняється від 1.0. Граничні константи FLT_EPSILON і DBL_EPSILON називають "машинними нулями" щодо дійсного значення 1.0. FLT_MIN, FLT_MAX і DBL_MAX - граничні значення для дійсних даних. FLT_MANT_DIG, DBL_MANT_DIG - кількість двійкових цифр (бітів) в мантисах відповідно чисел типу float і double.

Застосування дійсних даних.

Навіть познайомившись з

На IBM PC:

•  для float - 4 байти;

•  для double - 8 байт;

•  для long double - 10 байт.

Звернувши увагу на значення граничних констант, відмічають, що максимальні значення, які можна представити дійсними числами, визначені константами: FLT_MAX приблизно рівно 1Е+37 (для float);DBL_MAX приблизно рівно 1Е+308 (для double).Кількість вірних десяткових цифр в мантисах: FLT_DIG рівно 6 (для float);DBL_DIG рівно 10 (для double).  Мінімальні нормалізовані числа:

FLT_MIN приблизно рівно 1Е-37 (для float);

DBL_MIN приблизно рівно 1Е-308 (для double).

За замовчанням всі константи що не відносяться до цілих типів, приймають тип double.

Наступна програма ілюструє небезпеки, зв'язані із застосуванням даних типу float навіть

в нескладних арифметичних виразах:

#include <stdio.h>

void main(   )

{

float а,   b,   з,   t1,   t2,   t3;

a=95.0;

b=0.02;

t1= (a+b) * (a+b) ;

t2=-2.0*a*b-a*a;

t3=b*b;

c=(tl+t2)/t3;

printf("\nc=%f\n",   з); }

Результат виконання програми: c=2.441406

Якщо в тій же програмі змінної а присвоїти значення 100.0, то результат ще гірше:

с=0.000000.

Таким чином, запрограмоване з використанням змінних типу float нескладний алгебраїчний вираз

ніяк не "хоче" обчислюватися і приймати своє явне теоретично одиничне значення.

Якщо замінити в програмі тільки один рядок, тобто так оголосити змінні:

double а,   b,   c,   tl,   t2,   t3;

значення виразу обчислюється абсолютно точно: с=

1.000000

Наведений приклад і загальні положення обчислювальної математики примушує істотно обмежити застосування змінних типу float.

Тип float можна вибирати для представлення початкових даних або остаточних результатів в програмі. Проте застосування даних типу float в проміжних обчисленнях (особливо в ітераційних алгоритмах) слідує обмежити і завжди використати double або long double.

На жаль, ні double, ні long double не знімають повністю проблем кінцевої точності представлення дійсних чисел в пам'яті ЕОМ. Істотна відмінність в порядках значень операндів арифметичних виразів може привести до подібних некоректних результатів і при використанні типів double і long double.

Виділення лексем з тексту програми.

Перша задача яку вирішує компілятор - це лексичний аналіз тексту програми. В результаті лексичного   аналізу   з   суцільного   тексту   виділяються   лексичні одиниці (лексеми). Компілятор проглядає символи (літери) тексту програми зліва направо. При цьому його перша задача - виділити лексеми мови. За чергову лексичну одиницю приймається найбільша послідовність літер, яка утворює лексему. Таким чином, з послідовності int_line компілятор не стане виділяти як лексему службове слово int, а сприйме всю послідовність як введений користувачем ідентифікатор.

Відповідно до того ж принципу вираз d+++b трактується як d++   +b, а вираз b-->с еквівалентно (b--)>с. Наступна програма ілюструє сказане:

#include <stdio.h>

void main()

{

int n=10,m=2;

printf("\nn+++m=%d",n+++m);

printf("\nn=%d, m=%d",n,m);

printf("\nm—>n=%d",m—>n);

printf("\nn=%d, m=%d",n,m);

printf("\nn—>m=%d",n—>m);

printf("\nn=%d, m=%d",n,m); }

Результат виконання програми:

n+++m=12

n=11,m=2

m—>n=0

n=11, m=l

n-->m=l

n=10,m=l

Результати обчислення виразів n+++m, n-->m, m-->n повністю відповідають правилам інтерпретації виразів. Унарні операції ++ і -- мають ранг 2. Аддитивні операції + і - мають ранг 4. Операції відносин мають ранг 6.


 

А также другие работы, которые могут Вас заинтересовать

68156. ПСИХОЛОГІЧНІ ОСОБЛИВОСТІ ВІКОВОЇ ДИНАМІКИ СТРАХІВ У НАВЧАЛЬНІЙ ДІЯЛЬНОСТІ ШКОЛЯРІВ 240 KB
  Динамічний розвиток сучасного суспільства висуває до людини все більш високі вимоги. Для того, щоб бути активним учасником подій, людина має мобілізувати усі сили, як розумові, так і фізичні, що передбачає високий рівень психологічного напруження. Не секрет, що шкільне навчання часто супроводжується виникненням страхів.
68157. ОСНОВИ ТЕХНОЛОГІЧНОЇ ПІДГОТОВКИ АВІАЦІЙНОГО ВИРОБНИЦТВА СКЛАДНОПРОФІЛЬНИХ ВИРОБІВ НА БАЗІ АНАЛІТИЧНИХ МОДЕЛЕЙ ПРОЦЕСУ ФОРМОУТВОРЕННЯ 13.91 MB
  Виникає необхідність у зміненні підходів до теорії формоутворення. Процеси формоутворення при цьому багато в чому визначаються керівними програмами аналітичними залежностями інтерполяційних функцій законами розгону й гальмування робочих органів обладнання. Крім того шляхом застосування аналітичних моделей...
68158. ПРАВОВЕ РЕГУЛЮВАННЯ МІЖНАРОДНОЇ ТЕХНІЧНОЇ ДОПОМОГИ: СТАН, ТЕНДЕНЦІЇ ТА ПЕРСПЕКТИВИ РОЗВИТКУ 168.5 KB
  Розвиток міжнародних економічних відносин між країнами з різним рівнем економічного розвитку відбувається під впливом глобалізації економіки та світових інтеграційних процесів. Частиною цих відносин є відносини між донорами (міжнародними організаціями та індустріально розвиненими країнами) та країнами-реципієнтами...
68159. НАУКОВО-МЕТОДИЧНІ ПІДХОДИ ДО АДАПТИВНОГО УПРАВЛІННЯ ФАРМАЦЕВТИЧНИМИ ОРГАНІЗАЦІЯМИ 384 KB
  Залишаються актуальними комплексні дослідження від виділення факторів впливу зовнішнього середовища на діяльність підприємства до проведення оцінки ефективності адаптивних дій. Науковометодичне обґрунтування механізмів адаптивного управління фармацевтичними організаціями з урахуванням результатів...
68160. ФАКТОРНИЙ ПІДХІД ДО УПРАВЛІННЯ НАЦІОНАЛЬНОЮ ЕКОНОМІКОЮ 400.5 KB
  Сукупність глобалізаційних тенденцій, виражених поглибленням нерівномірності економічного розвитку, загострює актуальність дослідження факторного підходу до управління національними економіками. Неефективне використання факторів виробництва і зумовлені ним структурні диспропорції...
68161. МАТЕМАТИЧНІ МЕТОДИ ТА ІНСТРУМЕНТАЛЬНІ ЗАСОБИ РОЗВ’ЯЗАННЯ БАГАТОВИМІРНИХ ЗАДАЧ РОЗПОДІЛУ РЕСУРСІВ ПРОЕКТІВ БУДІВНИЦТВА В УМОВАХ НЕВИЗНАЧЕНОСТІ 434.5 KB
  Складність рішення даного завдання обумовлюється тим що ІБП завжди розвиваються в умовах жорстких обмежень на витрати ресурсів проекту та тривалість їх виконання. Тому важливим процесом в управлінні ІБП є оптимальний розподіл ресурсів проекту а саме фінанси сировини енергії обладнання трудових ресурсів тощо.
68162. ПРОФІЛАКТИКА КАНДИДО-АСОЦІЙОВАНОГО АЛЬВЕОЛІТУ 158 KB
  Клінічно на третю добу після екстракції зуба у першій контрольній групі було зареєстровано 17 327 випадків розвитку ускладнень у вигляді постекстракційного альвеоліту у другій 7 14 випадків й в основній 3 53. Так у першій контрольній групі запальні реакції були найбільш тривалими і зберігалися до 14 діб.
68163. Геохімія ртуті у підземних водах геологічних структур північно-західної частини Донецької складчастої споруди 269.5 KB
  Окрім того присутність ртуті у підземних водах може бути причиною важких неінфекційних хронічних захворювань у населення. Через все це дослідження геохімічних особливостей ртуті у підземних водах геологічних структур північнозахідної частини Донецької складчастої споруди є дуже актуальною науковопрактичною проблемою.
68164. Жанрово-стильова модель інструментального концерту та концепційні засади композиторської інтерпретації (на прикладі творів Л. М. Колодуба) 171 KB
  Вибір даної теми зумовлений науковим інтересом до зазначеної проблеми а постійне звертання композиторів до жанру інструментального концерту також засвідчує актуальність обраної тематики. Об’єктом дослідження обрано жанровостильову модель інструментального концерту.