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

Работа с динамической памятью. Обработка числовых и текстовых данных

14.05.2020, 14:36. Показов 1400. Ответов 7

Студворк — интернет-сервис помощи студентам
Не понимаю как сделать так чтобы выводился адрес ячейки в которой находится минимальный элемент. Помогите пожалуйста.
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
62
63
64
65
66
67
68
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
#include <cmath>
using namespace std;
 
void Min(float** a, int N, int M ,   float& min )
{
    int imin = 1000, jmin = 1000;
 
    for (int i = 0; i < N; i++) {
        for (int j = 0; j < M; j++) {
            if (i <= j && a[i][j] < min)
            {
                min = a[i][j];
                imin = i;
                jmin = j;
            }
        }
    }
    min = a[imin][jmin];
}
 
 
int main()
{
    srand((unsigned)time(0));
    puts ("If you follow the picture, our matrix must be square, otherwise it is not clear how to count");
    puts ("In the task, it is not clear how to correctly create conditions in cycles for a matrix of size N*M.");
    puts ("But the program works correctly:)");
    puts ("---I recommend square matrix---");
    int N,M;
    cout << " Enter the number of rows= ";
    cin >> N;
    cout << "Enter the number of columns= ";
    cin >> M;
    cout <<"----------------------------"<<endl;
 
    float** a = new float* [N];// Один из способов передачи динамического массива в функцию
    for (int i = 0; i < N; i++)
        a[i] = new float[N];
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < M; j++)
        {
            a[i][j] = (float)(rand()%20001)/200-100;
            cout << setw(3) << a[i][j] << " ";
        }
        cout << "\n";
    }
    float min = 1000.00;
    Min(a, N,M, min  );
    cout <<" ----------------------------"<<endl;
    cout << endl << "Local min element = " << min << "\n";
    puts("In the task it is not clear what is meant by \"results\"");
    puts("So I find a pointer to the minimum element")
 
 
 
    for (int i=0; i<N; i++){
        delete []a[i];
    }
    delete []a;
 
    system("pause");
    return 0;
}
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
14.05.2020, 14:36
Ответы с готовыми решениями:

Работа с динамической памятью. Обработка числовых и текстовых данных
Создать функцию для определения в строке слов, начинающихся со строчной буквы (возвращаются указатели на начало слов). Тестовая...

Работа с файлами текстовых данных. Обработка текста
Составить алгоритм и программу обработки текста 1) чтение строк текста из текстового файла и формирование массива слов текста; 2)...

Работа с динамической памятью
Здравствуйте, был в пятницу на собеседовании Задали такой вопрос - написать программму, которая бы создавала динамический список, то есть...

7
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
14.05.2020, 14:56
Цитата Сообщение от Nvy Посмотреть сообщение
Не понимаю как сделать так чтобы выводился адрес ячейки в которой находится минимальный элемент. Помогите пожалуйста.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
float *Min(float** a, int N, int M ,   float& min )
{
    int imin = 1000, jmin = 1000;
 
    for (int i = 0; i < N; i++) {
        for (int j = 0; j < M; j++) {
            if (i <= j && a[i][j] < min)
            {
                min = a[i][j];
                imin = i;
                jmin = j;
            }
        }
    }
    min = a[imin][jmin];
 
return &a[imin][jmin];
}
Добавлено через 1 минуту
C++
1
2
3
float min = 1000.00;
float  *p = Min(a, N, M, min);
std::cout << p << std::endl;
1
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.05.2020, 15:02
напишите оригинал условия задачи

Вы там про какую-то картинку говорите, сбросьте её тоже
1
0 / 0 / 0
Регистрация: 06.04.2020
Сообщений: 40
14.05.2020, 15:06  [ТС]
А, все вопрос исчерпан.

Добавлено через 1 минуту
Цитата Сообщение от Yetty Посмотреть сообщение
Вы там про какую-то картинк
Просто там многое в условие задачи не понятно
Создать динамическую вещественную матрицу NxM (N и M ввести с клавиатуры). Размещение в памяти: все строки матрицы располагаются в едином массиве (один запрос на выделение NxM элементов). Создать функцию, которая формирует массив результатов – возвращает указатели на мининальные элементы заштрихованной области.

Там треугольник выше главной диагонали матрицы
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.05.2020, 15:33
Цитата Сообщение от Nvy Посмотреть сообщение
А, все вопрос исчерпан
это Вам так только кажется минимальных в заштрихованной области может оказаться несколько. Ваша функция не формирует массив.
Цитата Сообщение от Nvy Посмотреть сообщение
Просто там многое в условие задачи не понятно
только один момент - если матрица квадратная, в условии пишут NxN
1
0 / 0 / 0
Регистрация: 06.04.2020
Сообщений: 40
14.05.2020, 15:37  [ТС]
Цитата Сообщение от Yetty Посмотреть сообщение
только один момент - если матрица квадратная, в условии пишут N*N
Ну просто тогда не понятно каким образом выделять главную дигональ
Изображения
 
0
0 / 0 / 0
Регистрация: 06.04.2020
Сообщений: 40
14.05.2020, 15:56  [ТС]
Цитата Сообщение от Yetty Посмотреть сообщение
только один момент - если матрица квадратная, в условии пишут N*N
А если матриц 2 x 10

Просто нет никакого уточнения как считать в таких случаях

Добавлено через 2 минуты
Цитата Сообщение от Yetty Посмотреть сообщение
это Вам так только кажется минимальных в заштрихованной области может оказаться несколько. Ваша функция не формирует массив.
Ну да здесь соглашусь

Добавлено через 15 минут
Цитата Сообщение от Yetty Посмотреть сообщение
это Вам так только кажется минимальных в заштрихованной области может оказаться несколько. Ваша функция не формирует массив.
А как вот это сделать?
Просто если я создаю min - динамический массив, то у меня все в функции ломается, хотя с ** проблем нет
Первая ошибка сразу же в if (i <= j && a[i][j] < min)
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
14.05.2020, 16:12
Лучший ответ Сообщение было отмечено Nvy как решение

Решение

Цитата Сообщение от Nvy Посмотреть сообщение
каким образом выделять главную диагональ
выделять диагональ Вам не нужно. Вам нужно сделать 2 цикла - в первом найти min, во втором - сравнить каждый элемент верхнего треугольника с min. перед этим посмотрите как в функции создать и возвратить массив.
Цитата Сообщение от Nvy Посмотреть сообщение
как считать в таких случаях
решайте задачу для квадратного массива - на картинке именно такой изображён (т.е. задавайте только N)

Добавлено через 2 минуты
Цитата Сообщение от Nvy Посмотреть сообщение
А как вот это сделать?
нужно посчитать количество минимальных и создать динамический массив такого размера. для его заполнения ещё третий цикл понадобится (это если не применять вектор).

Добавлено через 9 минут
Nvy, память кстати нужно выделить одним куском, а не так как Вы выделяете
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.05.2020, 16:12
Помогаю со студенческими работами здесь

Работа с динамической памятью
Привет всем. Я недавно начал изучать C++ и наткнулся на ошибку:&quot;двумерный динам.exe вызвал срабатывание точки останова&quot; при очистке...

Работа с динамической памятью
Всем привет! Начинающий программист(около нескольких недель), сейчас пишу программы чисто для себя, для тренировки на С++ Вот...сегодня...

Работа с динамической памятью
Помогите разобраться :) Задача: Создать стек. Написать функцию, определяющую, есть ли заданная компонента в стеке. Что такое...

Работа с динамической памятью
Корректно ли организованна работа с памятью? Функция workWith2DArray осуществляет некоторую работу, используя созданный вовне двумерный...

Работа с динамической памятью!
Привет! Такая задача: Необходимо выделить(по N Кб) и освободить всю динамическую память. Определить время выделения и освобождения, и объем...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru