Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Центр помощи > [С++]Операторы цикла do...while


Автор: Zotec 29.1.2012, 20:10
Известно  число  учеников  в  каждом  из  20 классов  школы.  На  сколько численность  самого  большого (по  числу  учеников)  класса  превышает численность самого маленького класса? 

Автор: darkart 29.1.2012, 21:30
Код

#include <iostream>

const unsigned int CLASSROOMS = 20;

int main( int argc, char* argv[] )
{

    unsigned int currentClassRoomNum;

    std::cout << "Number of students fo class 1?" << std::endl;
    std::cin >> currentClassRoomNum;

    unsigned int maxClassRoomNum = currentClassRoomNum;
    unsigned int minClassRoomNum = currentClassRoomNum;

    int currentClassRoom = 1;

    do
    {
        std::cout << "Number of students fo class " << currentClassRoom + 1 << "?" << std::endl;
        std::cin >> currentClassRoomNum;

        if( currentClassRoomNum > maxClassRoomNum )
        {
            maxClassRoomNum = currentClassRoomNum;
        }
        else if( currentClassRoomNum < minClassRoomNum )
        {
            minClassRoomNum = currentClassRoomNum;
        }
        ++currentClassRoom;
    }
    while( currentClassRoom < CLASSROOMS );

    std::cout << "Result = ( " << maxClassRoomNum << " - " << minClassRoomNum << " ) = " << maxClassRoomNum - minClassRoomNum << std::endl;

    ::system( "pause" );

    return 0;
}

Автор: Mirkes 30.1.2012, 09:49
Я в С не силен, но по моему в цикле ошибка, обработано будет на 1 класс меньше, чем требовалось. Скорее всего нужно заменить фрагмент 
Цитата(darkart @  29.1.2012,  21:30 Найти цитируемый пост)
        
Код

++currentClassRoom;    }    while( currentClassRoom < CLASSROOMS )
;

на 
Код

}
while( currentClassRoom++ < CLASSROOMS )

Автор: Zotec 30.1.2012, 22:04
Спасибо!

Автор: k0rvin 30.1.2012, 22:31
Цитата(Mirkes @ 30.1.2012,  09:49)
Я в С не силен, но по моему в цикле ошибка, обработано будет на 1 класс меньше, чем требовалось. Скорее всего нужно заменить фрагмент 
Цитата(darkart @  29.1.2012,  21:30 Найти цитируемый пост)
        
Код

++currentClassRoom;    }    while( currentClassRoom < CLASSROOMS )
;

на 
Код

}
while( currentClassRoom++ < CLASSROOMS )

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

Автор: Mirkes 31.1.2012, 05:44
Цитата(darkart @ 29.1.2012,  21:30)
Код

const unsigned int CLASSROOMS = 20;

int main( int argc, char* argv[] )
{
    int currentClassRoom = 1;

    do
    {
        ++currentClassRoom;
    }
    while( currentClassRoom < CLASSROOMS );
}


Я оставил в цикле только необходимое для разбора. 
Итак до начала цикла currentClassRoom = 1
после первого прохода 2 и т.д.

То есть после 19-го прохода currentClassRoom =20
условие While не выполнилось и обработка 20-го класса не будет произведена.
В чем я ошибся?

Теперь по поводу 
Цитата

А помещать операцию изменения счетчика в проверку условия цикла вообще плохая практика.

Я вообще то паскальщик, так что с моей точки зрения это не просто плохая практика...

Предложил этот вариант просто потому, что он требовал наименьшей модификации кода.

Автор: k0rvin 31.1.2012, 07:02
Цитата(Mirkes @ 31.1.2012,  05:44)
Цитата(darkart @ 29.1.2012,  21:30)
Код

const unsigned int CLASSROOMS = 20;

int main( int argc, char* argv[] )
{
    int currentClassRoom = 1;

    do
    {
        ++currentClassRoom;
    }
    while( currentClassRoom < CLASSROOMS );
}


Я оставил в цикле только необходимое для разбора. 
Итак до начала цикла currentClassRoom = 1
после первого прохода 2 и т.д.

То есть после 19-го прохода currentClassRoom =20
условие While не выполнилось и обработка 20-го класса не будет произведена.
В чем я ошибся?

В том, что в C, C++ и многих других ЯП принято начинать нумерацию с нуля и ввод первого (нулевого) класса происходит перед циклом, чтобы инициализировать минимальное и максимальное значения:
Код

    std::cout << "Number of students fo class 1?" << std::endl; // 0
    std::cin >> currentClassRoomNum;
    unsigned int maxClassRoomNum = currentClassRoomNum;
    unsigned int minClassRoomNum = currentClassRoomNum;

    int currentClassRoom = 1; // соответственно теперь нам осталось проверить с 1 по 19
    do { ...

Автор: Mirkes 31.1.2012, 10:13
Верно, недосмотрел. Хотя ввод данных в двух местах тоже странная практика.
Но все верно.

Автор: k0rvin 31.1.2012, 11:26
Цитата(Mirkes @ 31.1.2012,  10:13)
Верно, недосмотрел. Хотя ввод данных в двух местах тоже странная практика.
Но все верно.

Не всегда, в данном случае вполне уместна.

Автор: volatile 1.2.2012, 01:03
Цитата(k0rvin @  31.1.2012,  11:26 Найти цитируемый пост)
Не всегда, в данном случае вполне уместна. 

Уместно то оно уместно, но только в данном учебном случае, с жестко заданным количеством 
Цитата(Zotec @  29.1.2012,  20:10 Найти цитируемый пост)
20 классов  школы


В реальных программах так писать нельзя.
Например программа обломится при кол-ве классов равном 1.
(вполне, кстати, нормальное количество  smile )

Автор: darkart 1.2.2012, 01:42
volatile
Подсказать как исправить?  smile 

Автор: volatile 1.2.2012, 02:10
Цитата(darkart @  1.2.2012,  01:42 Найти цитируемый пост)
Подсказать как исправить?  

darkart, вопрос не ко мне.
(Исправить думаю сможет любой, мало-мальски пишущий на С++, главное тут заметить проблему во-время  smile )

Автор: Mirkes 1.2.2012, 03:07
Цитата(darkart @  1.2.2012,  01:42 Найти цитируемый пост)
volatile, Подсказать как исправить?    

Мне нужна подсказка. Причем язык значения не имеет. Но программа должна работать и при нулевом количестве классов. Именно это я имел в виду, когда писал 
Цитата(Mirkes @  31.1.2012,  10:13 Найти цитируемый пост)
Хотя ввод данных в двух местах тоже странная практика.

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

А насчет нулевых количеств классов в школах и других столь же якобы невозможных значений в профессиональной деятельности сталкиваюсь на каждом шагу.

Автор: k0rvin 1.2.2012, 07:05
Цитата(volatile @ 1.2.2012,  01:03)
Уместно то оно уместно, но только в данном учебном случае, с жестко заданным количеством

При чем тут жестко заданное количество, если речь идет об обработке только первого элемента вне цикла? Ты как иначе собрался инициализировать минимум и максимум?

Автор: darkart 1.2.2012, 11:36
 smile 
Код

#include <iostream>

const unsigned char CHOICE_YES = 'y';

int main( int argc, char* argv[] )
{

    int currentClassRoomNum;
    int classRooms;

    setlocale( LC_ALL, "Russian" );

    do
    {
        std::cout << "Количество классов?" << std::endl;
        std::cin >> classRooms;
        if( classRooms < 0 )
        {
            unsigned char choice;
            std::cout << "Количество классов не может быть отрицательным." << std::endl << "Прервать выполнение( y ), переввести данные( иначе ) )?" << std::endl;
            std::cin >> choice;
            choice = static_cast< unsigned char >( tolower( choice ) );
            if( choice == CHOICE_YES )
            {
                std::cout << "Выход..." << std::endl;
                system( "pause" );
                return 0;
            }
        }
    }
    while( classRooms < 0 );

    

    if( classRooms > 0 )
    {
        do
        {
            std::cout << "Количество учеников в классе №1?" << std::endl;
            std::cin >> currentClassRoomNum;
            if( currentClassRoomNum < 0 )
            {
                unsigned char choice;
                std::cout << "Количество учеников не может быть отрицательным." << std::endl << "Прервать выполнение( y ), переввести данные( иначе ) )?" << std::endl;
                std::cin >> choice;
                choice = static_cast< unsigned char >( tolower( choice ) );
                if( choice == CHOICE_YES )
                {
                    std::cout << "Выход..." << std::endl;
                    system( "pause" );
                    return 0;
                }
            }
        }
        while( currentClassRoomNum < 0 );

        int maxClassRoomNum = currentClassRoomNum;
        int minClassRoomNum = currentClassRoomNum;

        if( classRooms > 1 )
        {
            int currentClassRoom = 1;

            do
            {    
                do
                {
                    std::cout << "Количество учеников в классе №" << currentClassRoom + 1 << "?" << std::endl;
                    std::cin >> currentClassRoomNum;
                    if( currentClassRoomNum < 0 )
                    {
                        unsigned char choice;
                        std::cout << "Количество учеников не может быть отрицательным." << std::endl << "Прервать выполнение( y ), переввести данные( иначе ) )?" << std::endl;
                        std::cin >> choice;
                        choice = static_cast< unsigned char >( tolower( choice ) );
                        if( choice == CHOICE_YES )
                        {
                            std::cout << "Выход..." << std::endl;
                            system( "pause" );
                            return 0;
                        }
                    }
                }
                while( currentClassRoomNum < 0 );


                if( currentClassRoomNum > maxClassRoomNum )
                {
                    maxClassRoomNum = currentClassRoomNum;
                }
                else if( currentClassRoomNum < minClassRoomNum )
                {
                    minClassRoomNum = currentClassRoomNum;
                }
                ++currentClassRoom;
            }
            while( currentClassRoom < classRooms );
        }    

        std::cout << "Результат = ( " << maxClassRoomNum << " - " << minClassRoomNum << " ) = " << maxClassRoomNum - minClassRoomNum << std::endl;
    }
    else
        std::cout << "В школе нет классов..." << std::endl << "Печаль..." << std::endl << "Нет пути..." << std::endl << "Не результат." << std::endl;
    

    ::system( "pause" );

    return 0;
}


далее по программе парсинг строк smile 

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)