Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.54/13: Рейтинг темы: голосов - 13, средняя оценка - 4.54
6 / 0 / 0
Регистрация: 30.06.2012
Сообщений: 3

Оператор for,if ( найти два наибольших числа)

30.06.2012, 19:19. Показов 2661. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите пожайлуста....начал самостоятельно изучать С++, в основном по Дейтелу Х.М. но и видеуроки итд...
но вот в книге Дейтела есть в конце глав задачки...зациклился на одной не идет и все,,,
тут на форуме посмотрел не нашел ничего похожего...вообщем задачка...найти два набольших числа...из 10 чисел .
..но для простоты я беру пока 5, хотя разници большой нет...одно наибольшее нахожу а вот второе ну никак(
вот программа на одно наибольшое...тут бы добавить....но не идет и все (
Условие : числа вводяться только один раз.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include 
using namespace std;
 
int main ()
 
{
setlocale(LC_CTYPE,"Russian");
int x,i,max;
max=0;
 
for (i=0;i<5;i++)
{
cout << "Введите числа ";
cin >> x;
 
if ( max < x )
max=x;
 
cout << "Максимальное " << max << endl;
}
return 0;
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.06.2012, 19:19
Ответы с готовыми решениями:

Найти два наибольших числа в последовательности
1)Дана последовательность из М чисел. Найти в ней два наибольших числа.

Найти два наибольших числа из десяти
С одним числом написал, а вот чтобы найти два числа ума не хватает. Нужно использовать только одну переменную для ввода чисел. Число...

Найти два наибольших простых числа в матрице
Помогите,пожалуйста Задана матрица целых чисел A(m,n). Найти два наибольших простых числа. Первое простое число заменить минимальным...

5
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
30.06.2012, 19:25
C++
1
max=0;
При вводе отрицательных чисел неверно.
Если без массива, то нужно заводить переменную bool, которая менялась бы, когда мы устанавливали максимум (при вводе первого числа).
Мой тебе совет - используй массив.
Т.е.
C++
1
2
3
int array[10];
for (int i=0; i < 10; i++)
    cin>> array[i];
Дальше работай с ним так: первым обходом находишь максимум, вторым обходом просто в проверке ставишь if(array[i] > max2 && array[i] != max). Потом можешь посидеть и подумать, как уменьшить количество лишних итераций (узнавать первый максимум в цикле ввода).
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,711
Записей в блоге: 14
30.06.2012, 19:33
Вот решение:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include "iostream.h"
 
int main(int argc, char* argv[])
{
 
    int X[5],max_1,max_2,i,j;
 
    for (i=0; i < 5; i++)
    {
        cout << (i+1) << " - number: ";
        cin >> X[i];
    }
 
    max_1=X[0];
    max_2=X[1];
 
    for (i=0; i < 5; i++)
        if (X[i] > max_1) 
            max_1=X[i];
        else
            if (X[i] > max_2) max_2=X[i];
            
    cout << "max_1=" << max_1 << endl;
    cout << "max_2=" << max_2 << endl;
 
    return 0;
}
0
6 / 0 / 0
Регистрация: 30.06.2012
Сообщений: 3
01.07.2012, 12:47  [ТС]
Спасибо, но как раз я до изучения массивов и не дошел пока ) работаю с числами)....но если взять программму написанную тут для массива ...она не правильно работает ...теже ошибки что и у меня теряються некоторые числа....я нашел решение...мож у кого будет таже проблема ( в первом операторе if нада присваивать max2=max, тогда при следущем цикле при max< x; max2 получит переменную max, а дальше понятно :

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#include <iostream>
using namespace std;
 
int  main () // Нахождение двух наибольших чисел
 
{
                    setlocale(LC_CTYPE,"Russian");
   int x,i,max,max2;
 
   max=max2=0;
  
   for (i=0;i<5;i++)
   {
    cout << "Введите числа   ";
    cin >> x;
    
       if ( max < x )
           {
                        max2=max;
               max=x;
           }
       else
       {
           if ((max2<x)&&(max!=x)) // (x>max) так два наибольших могут быть равны
           max2=x;
       }
    
      
       cout << "Максимальное  " << max << endl;
       cout << "Максимальное2  " << max2 << endl;
   }
 
  
   return 0;
}
0
 Аватар для Vaiz
104 / 98 / 40
Регистрация: 01.07.2012
Сообщений: 277
01.07.2012, 13:40
Вот как вариант с массивом, просто сортируем пузыриком и выводим первые два элемента

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <conio.h>
using namespace std;
 
void main()
{
    setlocale(LC_ALL,"Rus");
    int i,j,tmp,x[10];
    for (i=0;i<10;i++)
    {
        cout<<"Введите x["<<i+1<<"]\t";
        cin>>x[i];
    }
    for(i=1;i<10;i++)
        for(j=9;j>=i; j--)
            if(x[j-1]<x[j])
            { tmp=x[j-1]; x[j-1]=x[j]; x[j]=tmp; }
    cout<<"Максимальное 1 "<<x[0];
    cout<<"\nМаксимальное 2 "<<x[1];
    getch();
}
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,711
Записей в блоге: 14
01.07.2012, 21:43
Строго говоря, мое решение правильно. В постановке не сказано: два различных числа.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
01.07.2012, 21:43
Помогаю со студенческими работами здесь

Даны четыре разных числа. Найти среди них два наибольших
Даны четыре разных числа. Найти среди них два наибольших. Чет я не понимаю как это все написать через if кто может написать ? как...

Даны четыре разных числа. Найти среди них два наибольших
Задача: Даны четыре разных числа. Найти среди них два наибольших. С применением if. Помогите написать код, пожалуйста

Найти два наибольших числа из всех введенных, при условии что цифры не повторяются
Вот сижу над очередной задачкой. Найти 2 наиболее высоких числа из 10 введенных, при условии что цифры не повторяются. Максимальное...

Найти два наибольших числа из четырёх используя if
Составить программу нахождения двух наибольших из четырёх чисел и вывести их в порядке возрастания.(используя условный оператор if)

Ввести N чисел с клавиатуры. Найти два наибольших числа
Здравствуйте. Я не давно начал работать с C#, мне попалась задачка и у меня возникли с ней трудности. Помогите пожалуйста решить: ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru