Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.69/26: Рейтинг темы: голосов - 26, средняя оценка - 4.69
0 / 0 / 0
Регистрация: 15.04.2010
Сообщений: 82
1

Поиск в массиве минимального элемента

20.04.2010, 06:33. Просмотров 4672. Ответов 7
Метки нет (Все метки)

Ребят помогите. дан массив n*n. нужно найти в каждом столбце минимальный элемент и записать данные в новый массив. подтолкните на путь истинный по таким вопросам :
1 - как найти мин. элемент в стобце (я примерно представляю но боюсь напотрачить)
2 - ну и соответственно как их записать в новый массив.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.04.2010, 06:33
Ответы с готовыми решениями:

Поиск минимального элемента в массиве
Используя шаблон функции реализовать следующие задачи: 1) считывание массива из стандартного...

Поиск минимального элемента в массиве
Помогите решить задачку,Вводим в ручную массив и в нем нужно найти минимальные элемент Заранее...

Поиск минимального элемента и его номера в массиве
Задание : Написать программу, в которой пользователь заполняет массив из 10 чисел. Найти: a....

Написать программу: поиск минимального элемента в массиве
Заполнить квадратную матрицу случайными числами (функция). найти минимальный из повторяющихся...

7
Почетный модератор
7328 / 2594 / 268
Регистрация: 29.07.2006
Сообщений: 13,583
20.04.2010, 07:06 2
1. Найти в массиве элемент с наименьшим значением
здесь код для поиска минимума. Каждый столбец матрицы есть одномерные массив.
2. Вы не поверите... новый_массив[индекс] = минимум, и так для каждого столбца.
0
0 / 0 / 0
Регистрация: 15.04.2010
Сообщений: 82
20.04.2010, 21:09  [ТС] 3
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
#include <iostream>
using namespace std;
 
 
int ** creat(int &n, int &m) 
{cout<<"n="; cin>>n; cout<<"m="; cin>>m;
int **mas=new int *[n];
for (int i=0; i<n; ++i) mas[i]=new int [m];
for (int i=0; i<n; ++i)
for (int j=0; j<m; ++j) {cout<<"mas["<<i<<"]["<<j<<"]="; cin>>mas[i][j];}
return mas;}
 
int main()
{int n;
cout<<"n="; cin>>n; cout<<"m="; cin>>m;
int **a creat(n,m);
float *b=new float[n];
int min=a[0][0];
for (int i=0; i<n; ++i)
for (int j=0; j<m; ++j)
if (a[i][j]<min)
min+=b[i];
cout<<"min= "<<b[i];
    return 0;
}
Правильно?
0
Эксперт С++
4709 / 2534 / 753
Регистрация: 18.08.2009
Сообщений: 4,550
20.04.2010, 21:21 4
Куча ошибок, кроме того, новый массив объявляете для элементов типом float, хотя работаете с элементами типа int. Круто!
0
0 / 0 / 0
Регистрация: 15.04.2010
Сообщений: 82
20.04.2010, 21:33  [ТС] 5
valeriikozlov, сорри.
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
#include <iostream>
using namespace std;
 
 
int ** creat(int &n, int &m) 
{cout<<"n="; cin>>n; cout<<"m="; cin>>m;
int **mas=new int *[n];
for (int i=0; i<n; ++i) mas[i]=new int [m];
for (int i=0; i<n; ++i)
for (int j=0; j<m; ++j) {cout<<"mas["<<i<<"]["<<j<<"]="; cin>>mas[i][j];}
return mas;}
 
int main()
{int n,m;
cout<<"n="; cin>>n; cout<<"m="; cin>>m;
int **a creat(n,m);
int *b=new int[n];
int min=a[0][0];
for (int i=0; i<n; ++i)
for (int j=0; j<m; ++j)
if (a[i][j]<min)
min+=b[i];
cout<<"min= "<<b[i];
    return 0;
}
теперб две ошибки.
Error 1 error C2146: syntax error : missing ';' before identifier 'creat'
Error 2 error C2065: 'i' : undeclared identifier
0
Эксперт С++
4709 / 2534 / 753
Регистрация: 18.08.2009
Сообщений: 4,550
20.04.2010, 21:52 6
Цитата Сообщение от LiLi R. Посмотреть сообщение
теперб две ошибки.
Error 1 error C2146: syntax error : missing ';' before identifier 'creat'
Error 2 error C2065: 'i' : undeclared identifier
Очень серьезные ошибки. Попробуйте вот так:
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
#include <iostream>
using namespace std;
 
 
int ** creat(int &n, int &m) 
{//cout<<"n="; cin>>n; m=n;
int **mas=new int *[n];
for (int i=0; i<n; ++i) mas[i]=new int [m];
for ( i=0; i<n; ++i)
for (int j=0; j<m; ++j) {cout<<"mas["<<i<<"]["<<j<<"]="; cin>>mas[i][j];}
return mas;}
 
int main()
{int n,m;
cout<<"n="; cin>>n; m=n;
int **a=creat(n,m);
int *b=new int[n];
int min=a[0][0];
for (int i=0; i<n; ++i)
{min=a[0][i];
for (int j=0; j<m; ++j)
if (a[j][i]<min)
{
    min=a[j][i];    
}b[i]=min;
}
for (i=0; i<n; ++i)
cout<<"min= "<<b[i]<<endl;
        return 0;
}
0
1545 / 911 / 193
Регистрация: 26.03.2010
Сообщений: 3,105
20.04.2010, 22:07 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
#include <iostream>
  
int main()
{
    setlocale( LC_ALL,"Russian" );
    int row,column;
    int i,j; // счетчики.
    std::cout << "Введите кол-во строк в массиве: ";
    std::cin >> row;
    std::cout << "Введите кол-во столбцов в массиве: ";
    std::cin >> column;
 
    int **MAS = new int *[row]; // выделение памяти для массива MAS.
    for (i = 0; i < row; i++)
    MAS[i] = new int [column];
 
    for (i=0; i<row; i++) // заполняем массив MAS.
    for (j=0; j<column; j++)
    {
        std::cout << "MAS["<< i <<"]["<< j <<"]: ";
        std::cin >> MAS[i][j];
    }
 
    int *MAS_min=new int [column]; // выделение памяти для массива MAS_min.
    int min;
 
    for (i=0; i<row; i++)
    {
        min=MAS[i][0]; 
        for (j=0; j<column; j++) // находим минимальный элемент в строке.
        if (min>MAS[i][j]) min=MAS[i][j];
 
        MAS_min[i]=min; // записываем во второй массив.
        std::cout << MAS_min[i] << "  ";
    }
 
    std::cout << std::endl;
    for (int i = 0; i < row; i++)
    delete []MAS[i];
    delete []MAS;
    delete []MAS_min;
    system("pause");
    return 0;
}
0
0 / 0 / 0
Регистрация: 15.04.2010
Сообщений: 82
20.04.2010, 23:41  [ТС] 8
valeriikozlov,
neske,
Спасиб вам большое. Сразу две версии программы покажу все охренеют.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.04.2010, 23:41

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

Поиск минимального элемента и его индекса в массиве
всем привет! не понимаю как искать в массиве тот элемент, который наименьший и вывести этот...

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

Поиск минимального элемента в трёхмерном массиве, используя адресную арифметику
1. Написать программу поиска минимального элемента в трёхмерном массиве используя адресную...

Написать шаблон функции, выполняющей поиск минимального элемента в целочисленном массиве
Помогите пожалуйста с программой. Заранее огромное спасибо!!! Написать шаблон функции,...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2020, vBulletin Solutions, Inc.