Читать «С++ для "чайников" .» онлайн - страница 28

Стефан Рэнди Дэвис

      double dValue ;

Начиная с этой строки, во всей остальной части программы переменная dValue может принимать значения типа double. Тип уже объявленной переменной изменить нельзя: dValue является действительной переменной и останется ею до конца программы. Рассмотрим, как решается присущая целочисленным переменным проблема отбрасывания дробной части. Для этого в объявлении все переменные определим как действительные ( тип double ):

      double dValue ;

      dValue = 1.0/3.0 + 2.0/3.0 + 2.0/3.0 ;

Это эквивалентно выражению

      dValue = 0.333... + 0.666... + 0.666... ;

которое даёт значение

       dValue = 1.666... ;

«Я записал значение 1.666... как число с бесконечным числом шестёрок, однако на самом деле такая запись по сути невозможна в силу того, что имеется предел количества цифр, которое может быть в переменной типа double

[]

«На прилагаемом компакт-диске в папке Cpp_Programs\Chap02 программы IntAverage и FloatAverage демонстрируют разобранные здесь примеры вычисления среднего значения.» 

[]

// 

/*  IntAverage — среднее 3 чисел, используя целочисленную арифметику. */

/*               Сперва сумма трёх отношений */

/*               ( сумма каждого числа разделённого на 3), */

/*               второе разделить сумму трёх чисел на 3. */

#include <cstdio>

#include <cstdlib>

#include <iostream>

using namespace std ;

int main( int nNumberofArgs , char* pszArgs[ ] )

{

    setlocale ( LC_ALL , ".1251" ) ; /* печать русских текстов */

    int nValue1 ;

    int nValue2 ;

    int nValue3 ;

    // введите три числа

    cout << "Эта программа вычисляет среднее трёх чисел типа int\n "

         << "integer ( целочисленной ) арифметики\n\n" ;

    cout << "Введите три целых числа:\n" ;

    cout << "n1 - " ;

    cin  >> nValue1 ;

    cout << "n2 - " ;

    cin  >> nValue2 ;

    cout << "n3 - " ;

    cin  >> nValue3 ;

    /*  Сперва сумма трёх отношений */

    cout << "n1/3 + n2/3 + n3/3 = " ;

    cout << nValue1/3 + nValue2/3 + nValue3/3 ;

    cout << "\n" ;

    /* Сейчас соотношение трёх сумм */

    cout << "( n1 + n2 + n3 ) / 3   = " ;

    cout << ( nValue1 + nValue2 + nValue3) / 3 ;

    cout << "\n" ;

    /* Пауза для того, чтобы посмотреть на результат работы программы */

    system( "PAUSE" ) ;

    return 0 ;

}

/* FloatAverage — среднее 3 чисел, используя арифметику с плавающей точкой.*/

/*                   В противном случае, так же как IntAverage */

#include <cstdio>

#include <cstdlib>

#include <iostream>

using namespace std ;

int main( int nNumberofArgs , char* pszArgs[ ] )

{

setlocale ( LC_ALL , ".1251" ) ; /* печать русских текстов */

    float fValue1 ;

    float fValue2 ;

    float fValue3 ;

    // введите три числа

    cout << "Эта програма вычисляет среднее трёх чисел типа float\n"