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

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

Восстановить пароль Регистрация
Другие темы раздела
Visual C++ CString в double http://www.cyberforum.ru/cpp-beginners/thread1830360.html
CEdit *editBoxPtr1 = (CEdit *)(this->GetDlgItem(IDC_EDIT1)); editBoxPtr1->GetWindowText(rString); Нужно CString преобразовать в double. как это сделать ?
C++ Как представлять двоичные числа в обратном и дополнительном коде, используя битовые операции? #include <iostream> #include <string> #include <algorithm> using namespace std; int main() { int n; cout << "Enter decimal number: "; http://www.cyberforum.ru/cpp-beginners/thread1830351.html
C++ Найти матрицу, получающуюся из заданной перестановкой строк
Дана целочисленная квадратная матрица порядка 6. Найти матрицу, получающуюся из данной перестановкой строк – первой с последней, второй – с предпоследней и т.д. Перестановка осуществляется при условии, что элемент главной диагонали обоих строк не равен нулю. Вывести исходную и преобразованную матрицы. Не получается перестановка :(
Подключение в проекте .hpp и .cpp файлов C++
Добрый день! Среда разработки Code Blocks 13.12 Компилятор GNU GCC В проекте существует 3 файла в проекте - main.cpp, SW229.cpp и basis.hpp // basis.hpp #ifndef BASIS_HPP_INCLUDED #define BASIS_HPP_INCLUDED #include <iostream> #include <fstream>
C++ Вычислить выражение по заданной формуле http://www.cyberforum.ru/cpp-beginners/thread1830315.html
Нужно написать программу вычисляющую произведение(приложил фото внизу) x - Вещественное, n - натуральное Совсем запутался, помогите разобраться. Вот мои наброски #include "stdafx.h" #include <iostream> #include <string> using namespace std; int _tmain(int argc, _TCHAR* argv)
C++ Вывести на консоль значения чётных элементов массива, сумму индексов нечётных элементов, и исходный массив Написать программу, которая выводит значения четных элементов массива, сумму индексов нечетных элементов массива, и исходный массив. Размерность массива определить с клавиатуры. Проверить создание динамического массива. Массив должен быть заполнен случайными числами из диапазона . Помогите плиз) подробнее

Показать сообщение отдельно
Switty
0 / 0 / 0
Регистрация: 15.05.2016
Сообщений: 17
20.10.2016, 07:16     Определить ближайшее к числу справа число, большее его самого. Стек
Помогите, пожалуйста, с заданием.
В строку выписан большой список действительных чисел (порядка нескольких миллионов записей). Для каждого числа из списка определить ближайшее к нему справа число, большее его самого. Результат оформить в виде файла, в котором сформировать строки вида
<число из списка> <найденное ближайшее>
Если ближайшего большего для очередного числа не нашлось, то вместо найденного числа вывести -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;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 21:59. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru