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

Дана прямоугольная матрица А размером N × M. Составить программу, которая преобразует матрицу следующим образом: поэлементно вычитает первый столбец - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Составить программу для подсчета суммы положительных элементов квадратной таблицы В, состоящей из N × N целых чисел http://www.cyberforum.ru/cpp-beginners/thread893354.html
Составить программу для подсчета суммы положительных элементов квадратной таблицы В, состоящей из N × N целых чисел, расположенных на побочной диагонали. Сформировать матрицу с помощью генератора случайных чисел и организовать ее вывод на экран. на языке с++ нужно
C++ деление на больше число =\ Раньше не сталкивался, однако теперь... как число (допустим 7, формата флоат) поделить на 10, что бы получить 0.7?... http://www.cyberforum.ru/cpp-beginners/thread893352.html
C++ Простое однократное слияние и работа с указателем
Не могу понять что тут нужно делать, буду благодарен за какой-либо совет или вариант решения 1.Простое однократное слияние. Разделить массив на п частей и отсортировать их произвольным методом. Отсортированный массив получить однократным слиянием упорядоченных частей. Для извлечения очередных элементов из упорядоченных массивов использовать массив из п индексов (по одному на каждый массив). ...
составить программу, которая находит максимальное и минимальное значение среди элементов одномерного массива Y, которая состоит из N целых чисел C++
составить программу, которая находит максимальное и минимальное значение среди элементов одномерного массива Y, которая состоит из N целых чисел и проверяет, является минимальное значение делителем максимального помогите пожалуйста))) Добавлено через 6 минут нужно на языке с++
C++ Дан список слов различной длины. Составить программу упорядочения списка слов: По их длине; По алфавиту http://www.cyberforum.ru/cpp-beginners/thread893323.html
Очень срочно!!!!! Дан список слов различной длины. Составить программу упорядочения списка слов: По их длине; По алфавиту.
C++ Ребята как удалить предыдущий символ? С++ Доброго времени суток. Ребята, как удалить предыдущий символ в cout? я знаю \r вернуться в начало, но он мне не подходит... Ну для примера : cout << "1" << "2" << "3" <<endl; а на экране вывело просто 13. Как мне избавиться от 2-ки??? подробнее

Показать сообщение отдельно
UranFlex
131 / 129 / 21
Регистрация: 25.05.2013
Сообщений: 233
06.06.2013, 17:39     Дана прямоугольная матрица А размером N × M. Составить программу, которая преобразует матрицу следующим образом: поэлементно вычитает первый столбец
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
94
95
96
97
98
//============================================================================
// Name        : matrix_rect_cols.cpp
// Author      : UranFlex
// Version     : 0.1 alpha
// Copyright   : GNU GPL
// Description : Дана целочисленная прямоугольная матрица А размером N Г— M.
//               Составить программу, которая преобразует матрицу следующим образом: поэлементно вычитает первый столбец из всех столбцов, кроме первого.
//               Первым столбцом является столбец с индексом 0.
//               C++, Ansi-style
//============================================================================
 
#include <iostream>
#include <ctime>
#include <cmath>
#include <cstdlib>
#include <iomanip>
 
using namespace std;
 
// функция заполняет динамический двумерный массив псевдослучайными данными
void FillArray( int** array, const int rows, const int cols, const unsigned randRange = 101, const int shift = -50 );
// функция выводит на экран массив
void PrintArray( int** array, const int rows, const int cols );
// функция поэлементно вычитает столбец num из всех столбцов, кроме num
void SubtractCol( int** array, const int rows, const int cols, const int num = 0 );
 
int main() {
 
    srand( time( 0 ) ); // засеять генератор случайных чисел
 
    int m, n; // переменные для хранения количества строк и столбцов матрицы соответсвенно
    // получаем от пользователя данные матрицы
    cout << "Введите количество строк и количество столбцов матрицы" << endl;
    cin >> m >> n;
 
    // создаем матрицу
    // организация двумерного динамического массива производится в два этапа
    // сначала создаётся одномерный массив указателей, а затем в цикле каждому элементу этого массива присваивается адрес одномерного массива
    int** matrix = new int*[ m ];
    for ( int i = 0; i < m; ++i )
        matrix[ i ] = new int[ n ];
 
    // заполняем матрицу псевдослучайными значениями типа int
    FillArray( matrix, m, n );
 
    // выводим матрицу на экран
    cout << "Исходная матрица:" << endl;
    PrintArray( matrix, m, n );
 
    // отнимаем поэлементно первый столбец из всех столбцов, кроме первого ( у первого индекс равн 0 )
    SubtractCol( matrix, m, n );
 
    // выводим преобразованную матрицу на экран
    cout << "Преобразованнуая матрица:" << endl;
    PrintArray( matrix, m, n );
 
    // последовательное уничтожение двумерного массива происходит в обратном порядке
    // сначала в цикле уничтожаются одномерные массивы ( непосредственно сами строки двумерного ),
    // а затем уничтожается массив указателей на строки.
    for ( int i = 0; i < m; ++i )
        delete[] matrix[ i ];
    delete[] matrix;
 
    return 0;
}
 
void FillArray( int** array, const int rows, const int cols, const unsigned randRange, const int shift ) {
    for ( int i = 0; i < rows; ++i )
        for ( int j = 0; j < cols; ++j )
            // заполняем двумерный массив псевдослучайными данными.
            // shift - начальное значение диапазона данных
            // randRange - ширина диапазона
            array[ i ][ j ] = shift + rand() % randRange;
}
 
void PrintArray( int** array, const int rows, const int cols ) {
    for ( int i = 0; i < rows; ++i ) {
 
        for ( int j = 0; j < cols; ++j )
            cout << setw( 4 ) << array[ i ][ j ];
 
        cout << endl;
    }
}
 
void SubtractCol( int** array, const int rows, const int cols, const int num ) {
 
    // если номер столбца больше возможного в данной матрице, то функция завершается
    if ( num >= cols )
        return;
 
    for ( int i = 0; i < rows; ++i ) {
        for ( int j = 0; j < cols; ++j )
            if ( j != num )
                array[ i ][ j ] -= array[ i ][ num ];
 
    }
}
 
Текущее время: 11:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru