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

Именить код. Из статистической сделать динамический массив - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Тема: работа со структурами http://www.cyberforum.ru/cpp-beginners/thread1049565.html
Составить программу, в которой описывается структура из полей: Фамилия, номер телефона, адрес. Организовать ввод двух структурных переменных, вывод каждой структуры на экран и вывести на экран Номер...
C++ слияние массивов даны 2 массива , массив А содержит n эле-тов и отсортирован по возрастанию, массив В содержит m эл-тов и отсортирован по убыванию.. написать программу для слияния этих массивов в массив С не... http://www.cyberforum.ru/cpp-beginners/thread1049552.html
Написать программу для решения системы уравнений с пом. матрицы C++
Добрый день! Очень прошу вашей подсказки в написании моей первой программы для решения системы уравнений с помощью матрицы! Собственно, сама система: a11x+a12y=b1 a21x+a22y=b2
C++ Уменьшить все четные элементы матрицы на значение максимального элемента
В с++ составить программу, в которой: 1) организовать ввод квадратной матрицы размера n*n из целых чисел 2) уменьшить все четные элементы матрицы на значение максимального элемента 3) упорядочить...
C++ Задание на граф. Рейсы автобуса. http://www.cyberforum.ru/cpp-beginners/thread1049531.html
Объект – рейс междугороднего автобуса. Известны началь-ный и конечный пункты рейса, время отправления, время прибытия, время в пути без учета стоянок, стоимость билетов. Выдать список маршрутов,...
C++ Реализовать задачу на проенты Реализовать задачу в виде функций выполняемых условно-бесконечном цикле "ввод данных - обработка - вывод - вопрос пользователю о новой итерации обработки" Коммерсант, имея стартовой капитал К1... подробнее

Показать сообщение отдельно
MrGluck
Модератор
Эксперт CЭксперт С++
7497 / 4613 / 694
Регистрация: 29.11.2010
Сообщений: 12,628
20.12.2013, 12:37
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
#include <cstdlib>
#include <ctime>
#include <iostream>
 
// ввод с клавиатуры матрицы A[M][N]
void input(int **A, const int M, const int N)
{
    for (int i=0; i < M; i++)
        for (int j=0; j < N; j++)
        {
            std::cout << "A[" << i << "][" << j << "] = ";
            std::cin >> A[i][j];
        }
}
 
// вывод матрицы A[M][N]
void output(int **A, const int M, const int N)
{
    for (int i=0; i < M; i++)
    {
        for (int j=0; j < N; j++)
            std::cout << A[i][j] << " ";
        std::cout << std::endl;
    }
}
 
// подсчет ненулевых элементов матрицы A[M][N]
int countNonzero(int **A, const int M, const int N)
{
    int counter = 0; // счетчик
    for (int i=0; i < M; i++)
    {
        for (int j=0; j < N; j++)
            if (A[i][j] != 0) // если элемент ненулевой
                counter++;    // увеличиваем счетчик
    }
    return counter;
}
 
// переставляет элементы второго столбца матрицы, кратные числу 4, в его начало
void mySpecialSwap(int **A, const int M, const int N)
{
    // проверяем, содержит ли матрица 2 столбец
    if (N < 2)
        return;
 
    int startPos = 0; // количество переставленных элементов
    // для каждой строки
    for (int i=0; i < M; i++)
        if (A[i][1] % 4 == 0) // если элемент кратен 4
        {
            // меняем его местами с первым в стобце, swap
            int tmp = A[startPos][1];
            A[startPos][1] = A[i][1];
            A[i][1] = tmp;
            startPos++; // увеличиваем количество переставленных элементов
        }
}
 
 
int main()
{
    int **A, N; // квадратная матрица и размерность
    std::cout << "N = ";
    std::cin >> N;
    if (N < 1) return 1; // защита от дурака
 
    // выделяем память под N "строк"
    A = new int*[N];
    // для каждой строки выделяем память под N элементов
    for (int i=0; i < N; i++)
        A[i] = new int[N];
 
    input(A, N, N);  // ввод матрицы
 
    // выводим количество ненулевых элементов
    std::cout << "Nonzero elements: " << countNonzero(A, N, N) << std::endl;
 
    // переставляем элементы второго столбца матрицы, кратные числу 4, в начало
    mySpecialSwap(A, N, N);
 
    output(A, N, N); // вывод матрицы
 
    // память больше не нужна, освобждаем её
    for (int i=0; i < N; i++)
        delete[] A[i];
    delete[] A;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.