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

Посчитать кол-во элементов между максимальным и минимальным значением элементов двумерного массива( подразумевается, что эти значения уже найдены) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ too few arguments to .Как правильно исправить ? http://www.cyberforum.ru/cpp-beginners/thread810651.html
Нужно найти точки перегиба функций Больше всего ошибок too few arguments to function выбивает внутри функции void tochki(float *proizv2(float,float),float xn,float xk,float dx) на 32, 36, 38...
C++ Калькулятор. Ввод выражения Начинаю писать калькулятор на C++, нужно вводить выражение после получить результат. Программа должна считать выражение, например, 2+3+5-2*4. То есть кол-во переменных неизвестно заранее. Как... http://www.cyberforum.ru/cpp-beginners/thread810640.html
Задача, for,while,do-while (определить минимальное число во введенной с клавиатуры последовательности положительных чисел) C++
Добрый вечер! Прошу помогите решить задачу, ничего не выходит. Точнее не пойму как сделать. Использовать можно только for,while,do-while. Сама задача: "Написать программу, которая определяет...
C++ Воросы по Queues
Добрый день!!! У меня возникли вопросы при изучении темы Queues: 1) чем же на самом деле отличаются Queues и Stack (один из них требует динимическую память, один из них использует 2 конца...
C++ Рекурсия (вычисление суммы, вывод элементов одномерного массива в обратном порядке) http://www.cyberforum.ru/cpp-beginners/thread810627.html
Я хочу реализовать рекурсивные функции:1)вычисления суммы k первых членов арифметической прогрессии. 2)вывода в консоль элементов одномерного массива в обратном порядке. Подскажите как сделать....
C++ Чтение из файла по одному символу Здравствуйте! Перешел с Pascal но C++. Стоит задача - вывести сумму двух длинных чисел с 30 тыс. раздрядов, т.е. реализовать длинную арифметику. Все сделал, все работает, только не умею читать из... подробнее

Показать сообщение отдельно
xtorne21st
интересующийся
304 / 275 / 19
Регистрация: 25.09.2010
Сообщений: 1,056
17.03.2013, 19:42
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
56
57
58
59
60
61
#include <iostream>
#include <ctime>
#include <cstdlib>
 
const int LENGTH = 5;
const int HEIGHT = 2;
 
int arr[HEIGHT][LENGTH];
 
void show_arr()
{
    for (int i = 0; i < HEIGHT; ++i)
        for (int j = 0; j < LENGTH; ++j)
        {
            std::cout << arr[i][j];
            std::cout << ((j % LENGTH == LENGTH - 1) ? '\n' : ' ');
        }
}
 
void gen()
{
     for (int i = 0; i < HEIGHT; ++i)
        for (int j = 0; j < LENGTH; ++j)
            arr[i][j] = std::rand() % 100;
}
 
int cnt()
{
    const int* const b = reinterpret_cast<int*>(arr);
    const int* pb = b;
    const int* min_p = b, *max_p = b;
    while (pb < b + (HEIGHT * LENGTH))
    {
        if (*pb > *max_p)
            max_p = pb;
        if (*pb < *min_p)
            min_p = pb;
        ++pb;
    }
    std::cout << "Min = " << *min_p << ", max = " << *max_p << '\n';
    
    if ((b + (HEIGHT * LENGTH)) - max_p > (b + (HEIGHT * LENGTH) - min_p))
    {
        const int* tmp = max_p;
        max_p = min_p;
        min_p = tmp;
    }
    int count_ix = 0;
    for (++min_p; b + (HEIGHT * LENGTH) - min_p > (b + (HEIGHT * LENGTH) - max_p); ++min_p)
        ++count_ix;
 
    return count_ix;
}
 
int main()
{
    std::srand(time(0));
    gen();
    show_arr();
    std::cout << cnt() << '\n';
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru