Форум программистов, компьютерный форум 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 строке Понимаю что не все параметры передаю внутри функции, но как их правильно передать, если у меня значения float xn,float xk для исследуемых функций различны??если б для одной - можно было б...
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 конца (ends) структуры); 2) Если данные это circular массив of CAPACITY elements, и последний это индех этого массива, какая должна быть формула для индекса следующего за последним? A) (last % 1) + CAPACITY...
C++ Рекурсия (вычисление суммы, вывод элементов одномерного массива в обратном порядке) http://www.cyberforum.ru/cpp-beginners/thread810627.html
Я хочу реализовать рекурсивные функции:1)вычисления суммы k первых членов арифметической прогрессии. 2)вывода в консоль элементов одномерного массива в обратном порядке. Подскажите как сделать. Заранее спасибо)
C++ Чтение из файла по одному символу Здравствуйте! Перешел с Pascal но C++. Стоит задача - вывести сумму двух длинных чисел с 30 тыс. раздрядов, т.е. реализовать длинную арифметику. Все сделал, все работает, только не умею читать из файла по одному символу. В файле записаны 2 числа в 2х строках. Каждое число состоит из 30000 разрядов. Считываю эти числа в 2 массива типа char, по разряду в каждый элемент массива. Вопрос: как... подробнее

Показать сообщение отдельно
xtorne21st
интересующийся
300 / 271 / 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';
}
 
Текущее время: 09:13. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru