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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
DeadDanny
0 / 0 / 0
Регистрация: 13.12.2010
Сообщений: 3
#1

Массивы - C++

13.12.2010, 14:45. Просмотров 301. Ответов 1
Метки нет (Все метки)

Помогите сделать 2 задания для Borland C++, в долгу не останусь.
1) В двумерном массиве A(n,m) заменить нулями все элементы, стоящие в строках и столбцах, где имеются нули. (Условие: можно завести вспомогательный одномерный массив, но нельзя заводить вспомогательный двумерный массив)
2) Найти число элементов массива Y(n), значения которых совпадают со значениями X(n).
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.12.2010, 14:45     Массивы
Посмотрите здесь:

Упорядочить массивы по по убыванию, потом соединить массивы в один упорядоченный массив - C (СИ)
Начала писать, запуталась Даны два одномерных массива состоящие из 10 целых чисел. Упорядочить массивы по по убыванию, потом соединить...

Даны массивы A(8), F(8),Q(8). Сформировать массивы С(8), каждый элемент которого вычисляется по формуле - Pascal ABC
uses crt; type mas=array of integer; var A,F,Q,C:mas; i,s:integer; begin clrscr; writeln('Массив первый:'); for i:=1...

Даны массивы а и b. Получить новые массивы a и b, элементы которых вычисляются по правилу: ai=bi, bi= -ai - Pascal
Даны массивы а и b, состоящие из n-элементов каждый. Получить новые массивы a и b, элементы которых вычисляются по правилу: ai=bi, bi=...

Табулирование функции и поиск данных. Одномерные массивы. Двумерные массивы - C#
Вычислить сумму первых четырех отрицательных элементов. В соответствии с п. 5.16 правил "Запрещено создавать темы с множеством...

Массивы. Циклические алгоритмы (Заполнить массивы случайными числами, лежащими в интервале 0 до 100) - C++
Доброго дня, уважаемые форумчане, помогите пожалуйста решить задание. Заполнить массивы случайными числами, лежащими в интервале 0 до...

Указатели и массивы. Индексация с помощью указателей. Передача массивов в функции. Динамические массивы (обработка матриц) - C++
Для каждого элемента , bij, i= 1,...,n , j=1,...,n определяется свой многоугольник местонахождением соответствующего элемента aij (см....

Файлы. Компоненты - массивы чисел. Переформировать файл, где сначала идут массивы с положительными макс. элементами - Turbo Pascal
Здравствуйте!! я пишу такую задачу: нужно написать две программы, одна из них создает файл, где компоненты - массивы вещ. чисел; ...

Многомерные массивы, как перебирать внутренние массивы - C++
Здравствуйте. Такой учебный код и плохо понимаю как перебираются внутренние массивы, может кто пояснит подоходчивее. Именно внутренний...

Попадание точки. Массивы чисел. Массивы записей. - C++
Всем привет. По языкам задали три контрольные на си. Я сам си не знаю, даже не представляю, поэтому очень нужна ваша помощь. ...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
asics
Freelance
Эксперт С++
2846 / 1783 / 144
Регистрация: 09.09.2010
Сообщений: 3,841
13.12.2010, 15:12     Массивы #2
Цитата Сообщение от DeadDanny Посмотреть сообщение
1) В двумерном массиве A(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
#include <iostream>
#include <ctime>
#include <cstdlib>
#include <iomanip>
 
int main()
{
        const size_t R = 3;
        const size_t C = 3;
        int matr[R][C], r[R], c[C], cnt, k = 0, _j = 0;
        srand(time(0));
 
        for(int i = 0; i < R; ++i)
        {
            for(int j = 0; j < C; ++j)
            {
                matr[i][j] = rand() % 5;
                std::cout << std::setw(2) << matr[i][j] << ' ';
            }
            std::cout << '\n';
        }
 
        for(int i = 0; i < R; ++i)
        {
            cnt = 0;
            for(int j = 0; j < C; ++j)
                if(!(matr[i][j]))
                    ++cnt;
 
            if(cnt >= 1)
            {
                r[k] = i;
                ++k;
            }
        }
 
        for(int i = 0; i < C; ++i)
        {
            cnt = 0;
            for(int j = 0; j < R; ++j)
                if(!(matr[j][i]))
                    ++cnt;
 
            if(cnt >= 1)
            {
                c[_j] = i;
                ++_j;
            }
        }
 
        for(int i = 0; i < k; ++i)
        {
            for(int j = 0; j < C; ++j)
            {
                matr[r[i]][j] = 0;
            }
        }
 
        for(int i = 0; i < _j; ++i)
        {
            for(int j = 0; j < R; ++j)
            {
                matr[j][c[i]] = 0;
            }
        }
 
        std::cout << '\n';
        for(int i = 0; i < R; ++i)
        {
            for(int j = 0; j < C; ++j)
            {
                std::cout << std::setw(2) << matr[i][j] << ' ';
            }
            std::cout << '\n';
        }
        return 0;
}
Ответ Создать тему
Опции темы

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