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

Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с отрицательными элем - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Сформировать строки таким образов, что бы первой была самая короткая строка, а последней самая длинная http://www.cyberforum.ru/cpp-beginners/thread897461.html
задан строка. сформировать строки таким образов что бы первой была самая короткая строка а последней самая длинная (все остальные строки остаются как были) например так: (исходный текст: "жили у бабуси два веселых гуся" --> сформированный текст: " у жили бабуси два гуся веселых")
C++ sortirovka slov задан текст. выполнить сортировку слов расположив их в порядке увеличения букв. (пример: qqqq ssssssss dfghdfagkhbbgfd kjdfkgkdnlglhmeurtiuerbgn) http://www.cyberforum.ru/cpp-beginners/thread897452.html
Сортировка слиянием C++
Объясните пожалуйста как сделать рекурсивную сортировку слиянием списка. Список имеет такие элементы struct List { int data; List* next; }; Единственное, что понял,надо рекурсивно делить списки по палам, а вот когда сортировать не знаю.
C++ Проблемы с VS 2012
Имеется код, он прекрасно работает в Visual Studio 2008, но при компиляции в 2012 версии выдает такую вот ошибку. Как от нее можно отделаться и вообще отделаться от ошибок 2012 версии :) #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <iostream> #include <conio.h> using namespace std; int main(int argc, char* argv)
C++ нужно перевести с паскаля на с++ http://www.cyberforum.ru/cpp-beginners/thread897437.html
uses crt; var E,x,p,t:real; k:integer; { Возведение х в степень к } function step(x:real;k:integer):real; var i: integer; st: real; begin st:=1;
C++ Найти узел, имеющий ближайший к значению ключ Всем привет. Есть условие. первая часть уже решена. помогите пожалуйста найти узел, имеющий ближайший к этому значению ключ. #include<iostream.h> struct node { int Key; int Count; node *Left; node *Right; подробнее

Показать сообщение отдельно
MarVaL
С++ Beginner
 Аватар для MarVaL
116 / 116 / 16
Регистрация: 28.02.2013
Сообщений: 246
10.06.2013, 18:09     Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с отрицательными элем
Без минимально элемента.
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#include <iostream>
#include <iomanip>
#include <cstdlib>
#include <ctime>
 
int** createMatrix(int, int);
void fillMatrix(int **, int, int );
void printMatrix(int **, int, int);
bool isNegative(int **, int, int);
void moveRow(int **, int, int, int);
void freeMatrix(int **, int);
 
int main() {
  setlocale(0, "");
  int n, m;
  std::cout << "n = ";
  std::cin >> n;
  std::cout << "m = ";
  std::cin >> m;
 
  int **matrix = createMatrix(n, m); 
  fillMatrix(matrix, n, m);
 
  std::cout << "Матрица:" << std::endl;
  printMatrix(matrix, n, m);
  
  for(int j = 0; j < n; ++j) {
    for(int i = 0; i < n; ++i) {
      if(isNegative(matrix, i, m)) {
        moveRow(matrix, i, n, m);
      }
    }
  }
 
  std::cout << "Матрица с перестановкой: " << std::endl;
  printMatrix(matrix, n, m);
 
  freeMatrix(matrix, n);
 
  std::cin.get();
  std::cin.get();
  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) {
  srand(time(0));
  for(int i = 0; i < n; ++i)
    for(int j = 0; j < m; ++j)
      matrix[i][j] = -3 + rand() % 12;
}
 
void printMatrix(int **matrix, int n, int m) {
  for(int i = 0; i < n; ++i) {
    for(int j = 0; j < m; ++j)
      std::cout << std::setw(4) << matrix[i][j];
    std::cout << std::endl;
  }
}
 
bool isNegative(int **matrix, int row_index, int m) {
  for(int j = 0; j < m; ++j)
    if(matrix[row_index][j] < 0)
      return true;
  return false;
}
 
void moveRow(int **matrix, int row_index, int n, int m) {
  for(int j = 0; j < m; ++j) {
    matrix[row_index][j] = 0;
  }
  if(row_index == n - 1)
    return;
  for(int i = row_index; i < n - 1; ++i) {
    for(int j = 0; j < m; ++j) {
      int temp = matrix[i][j];
      matrix[i][j] = matrix[i + 1][j];
      matrix[i + 1][j] = temp;
    }
  }
}
 
void freeMatrix(int **matrix, int n) {
  for(int i = 0; i < n; ++i)
    delete[] matrix[i];
  delete [] matrix;
}
 
Текущее время: 12:37. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru