С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

Массив: Освобождение выделенной памяти - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Заполнить структуру данными из бинарного файла http://www.cyberforum.ru/cpp-beginners/thread909393.html
Мне нужно заполнить структуру Note данными из бинарного файла. У меня есть такие структуры: struct Name { string First_Name;//имя string Patronym; //отчество string Last_Name; //фамилия };...
C++ Выход из цикла по нажатию определенной клавиши Допустим у меня есть какой-нибудь while(1) и мне нужно, чтобы при нажатии, например, esc или enter цикл завершался, как такое сделать? Добавлено через 8 минут А еще лучше, чтобы для продолжения... http://www.cyberforum.ru/cpp-beginners/thread909376.html
C++ Наследование, нахождения произведения и сложения матриц
Организовать производный класс, дополнительно содержащий функции нахождения произведения и сложения матриц. Программу написал, но почему-то значения во всех матрицах задаются одинаково? class.cpp...
После каждого четного элемента массива вставить 2 элемента с тем же значением, полученный массив отсортировать C++
после каждого четного элемента массива вставить 2 элемента с тем же значением.полученный масив отсортировать.очень хотелось бы с комментариями. пример вывода на экран исх массив ...
C++ Описать класс «вектор». Перегрузить операции * (скалярное произведение, умножение на скаляр) http://www.cyberforum.ru/cpp-beginners/thread909368.html
Помогите пожалуйста описать класс «вектор». Перегрузить операции * (скалярное произведение, умножение на скаляр), =. Протестировать работоспособность каждого метода вашего класса. а то экз завтра а...
C++ Не могу понять, что за ошибка (В матрице поменять местами столбцы, чтобы минимальные элементы образовывали возрастающую последовательность) Суть задачи состроит в том, дана матрица размера n на m. задается двумерный массив(рандомно). нужно поменять местами столбцы что бы минимальные элементы образовывали возрастающую последовательность.... подробнее

Показать сообщение отдельно
Forumhelp
1 / 1 / 0
Регистрация: 06.06.2013
Сообщений: 130
23.06.2013, 00:26  [ТС]
Спасибо за помощь))

Вот исправил. Есть какие то замечания?

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
69
70
71
72
73
74
75
76
77
#include <iostream>
#include <cstdlib>
#include <ctime>
#include <conio.h>
/* Prototipi */
int** createMatrix(int, int);
void fillMatrix(int**, int, int);
void printMatrix(int **, int, int);
int getIndexOfMinElement(int **, int, int);
void reverseFirstWithMin(int **, int, int);
 
 
int main() {
  srand(time(0));                                     
  int n, m, index;
  std::cout << "n = ";
  std::cin >> n;                                      
  std::cout << "m = ";
  std::cin >> m;                                      
  int **matrix = createMatrix(n, m);                 
  fillMatrix(matrix, n, m);                      
  printMatrix(matrix, n, m);                         
  index = getIndexOfMinElement(matrix, n, m);         
  reverseFirstWithMin(matrix, m, index);             
  printMatrix(matrix, n, m);                        
  for(int i = 0; i < n; ++i)
    delete[] matrix[i];                          
  delete[] matrix; 
  getch();                          
  return 0;
}
 
int** createMatrix(int n, int m) {
  int **matrix = new int*[n];                        
  for(int i = 0; i < n; ++i)
    matrix[i] = new int[m];                        
  return matrix;                                    
}
 
void fillMatrix(int **matrix, int n, int m) {
  for(int i = 0; i < n; ++i)                        
    for(int j = 0; j < m; ++j)
      matrix[i][j] = 1 + rand() % 9;
}
 
void printMatrix(int **matrix, int n, int m) {
  std::cout << "Matrix:" << std::endl;
  for(int i = 0; i < n; ++i) {
    for(int j = 0; j < m; ++j)
      std::cout << matrix[i][j] << ' ';               
    std::cout << std::endl;
  }
  std::cout << std::endl;
}
 
int getIndexOfMinElement(int **matrix, int n, int m) {
  int min = matrix[0][1];                                
  int index = 0;                                    
  for(int i = 0; i < n; ++i) {
    for(int j = 0; j < m; ++j)
      if(min > matrix[i][j]) {                      
        index = i;                                   
        min = matrix[i][j];                          
      }
  }
  return index;                                     
}
 
void reverseFirstWithMin(int **matrix, int m, int index) {
  if(index == 0)                                     
    return;                                        
  for(int j = 0; j < m; ++j) {
    int tmp = matrix[0][j];                        
    matrix[0][j] = matrix[index][j];               
    matrix[index][j] = tmp;                        
  }
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.