Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Определить ближайшее к числу справа число, большее его самого. Стек - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как представлять двоичные числа в обратном и дополнительном коде, используя битовые операции? http://www.cyberforum.ru/cpp-beginners/thread1830351.html
#include <iostream> #include <string> #include <algorithm> using namespace std; int main() { int n; cout << "Enter decimal number: ";
C++ Найти матрицу, получающуюся из заданной перестановкой строк Дана целочисленная квадратная матрица порядка 6. Найти матрицу, получающуюся из данной перестановкой строк – первой с последней, второй – с предпоследней и т.д. Перестановка осуществляется при... http://www.cyberforum.ru/cpp-beginners/thread1830340.html
Подключение в проекте .hpp и .cpp файлов C++
Добрый день! Среда разработки Code Blocks 13.12 Компилятор GNU GCC В проекте существует 3 файла в проекте - main.cpp, SW229.cpp и basis.hpp // basis.hpp #ifndef BASIS_HPP_INCLUDED #define...
Вычислить выражение по заданной формуле C++
Нужно написать программу вычисляющую произведение(приложил фото внизу) x - Вещественное, n - натуральное Совсем запутался, помогите разобраться. Вот мои наброски #include "stdafx.h" #include...
C++ Вывести на консоль значения чётных элементов массива, сумму индексов нечётных элементов, и исходный массив http://www.cyberforum.ru/cpp-beginners/thread1830314.html
Написать программу, которая выводит значения четных элементов массива, сумму индексов нечетных элементов массива, и исходный массив. Размерность массива определить с клавиатуры. Проверить создание...
C++ Добавление столбца в динамическую матрицу Доброго времени суток. Возникла проблема с методом добавления столбца в динамическую матрицу. Подскажите ошибку, пожалуйста void Matrix::addCols(int index) { int **tmp = new int*; for (size_t i... подробнее

Показать сообщение отдельно
Switty
0 / 0 / 0
Регистрация: 15.05.2016
Сообщений: 18

Определить ближайшее к числу справа число, большее его самого. Стек - C++

20.10.2016, 07:16. Просмотров 262. Ответов 4
Метки (Все метки)

Помогите, пожалуйста, с заданием.
В строку выписан большой список действительных чисел (порядка нескольких миллионов записей). Для каждого числа из списка определить ближайшее к нему справа число, большее его самого. Результат оформить в виде файла, в котором сформировать строки вида
<число из списка> <найденное ближайшее>
Если ближайшего большего для очередного числа не нашлось, то вместо найденного числа вывести -1.
Написал код, который, вроде работает правильно при рандомных числах, но если все числа будут идти на убывание, например: 30 20 15 10 5, то программа не работает, помогите исправить код.

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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "stdafx.h" 
#include <iostream> 
#include <ctime> 
#include <fstream> 
using namespace std;
 
 
int main()
{
    setlocale(LC_ALL, "Russian");
    unsigned int start_time = clock();
    ifstream robo("Text.txt"); 
    const int n = 5; //Сколько чисел, столько и тут над
    float b[n];
    for (int i = 1; i <= n; ++i)
    {
        robo >> b[i];
    }
    int max = b[1];
    for (int i = 1; i <= n; ++i)
    {
        if (max < b[i]) max = b[i];
    }
    for (int i = 1; i <= n; ++i)
    {
        for (int y = 1; y <= n; ++y)
        {
            if (b[i]<b[y])
            {
                cout << b[i] << ' ' << b[y] << endl;
                if (i <= n)
                {
                    ++i;
                    y = i-1;
                }
            }
            else {
                if (b[i] == max)
                {
                    cout << b[i] << ' ' << - 1 << endl;
                    break;
                }
                if (i == n)
                {
                    cout << b[i] << ' ' << - 1 << endl;
                    cout << "Value is not" << endl;
                    exit(0);
                }
            }
        }
 
    }
    cout << clock() / 1000.0 << " " << "секунд" << endl;
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru