Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.71/7: Рейтинг темы: голосов - 7, средняя оценка - 4.71
0 / 0 / 1
Регистрация: 16.09.2014
Сообщений: 26

Элементы столбцов матрицы, не содержащих положительных элементов, заменить суммой их цифр

18.09.2014, 23:47. Показов 1342. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Элементы столбцов целочисленного массива А(И,М), не содержащих положительных элементов, заменить суммой их цифр.

то есть как я понял.. если в массиве в каком либо столбце отрицательные числа, то на место их записуется сумма этих чисел!
помогите, завтра сдавать. уже 2 день пытаюсь сделать .

вот что у меня получилось. что то не так происходит . может по другому знаете как лучше
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
#include<iostream>
using namespace std;
int i,j;
int main()
{
    int Arr[3][3];
    for (int i = 0; i < 3; i++)
    {
        for (int j=0; j < 3;j++)
        {
            cout<<"vvedi mas["<<i<<"]["<<j<<"]: ";
            cin>> Arr[i][j];
        }
    }
    
    
    
    
    
    
    for (int i=0;i<3;i++) //иду по столбцам
    {
        bool marker = true;
        
        for (int j=0; j<3; j++) //по каждому элементу столбца
        {
            if (Arr[j][i] < 0) 
            { //сравниваю с нулем
                marker = false; //если меньше то макрек в фолс 
                break; //перехожу к след столбцу
            }
        }
        if (marker == true) //если все ок то
        {
            for (int j=0;j<3;j++) //прохожу по каждому элементу 
            {
                int num;
                
                num = Arr[i][j];
                
                int sum;
            
                while (num != 0) //нахожу сумму цифр
                {
                    sum=sum+num%10; 
                    num=num/10; 
                }
            
                Arr[j][i] = sum; //заменяю
                
                sum = 0;
                
                num = 0;
        
            }
    
        }
    }
    
    
    
    
    
    
    
    cout<<endl;
    
    for (int i=0; i<3; i++)
    {
        for (int j = 0; j < 3;j++)
        {
            cout<<"\t"<<Arr[i][j]; 
            cout.width(2);
        }
        
        cout<<endl;
    }
    
    return 0;
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.09.2014, 23:47
Ответы с готовыми решениями:

Элементы столбцов массива, не содержащих положительных элементов, заменить суммой их цифр
Элементы столбцов целочисленного массива А(N,М), не содержащих положительных элементов, заменить суммой их цифр. то есть как я понял.....

Элементы столбцов содержащих менее 10 положительных элементов заменить на элементы из другого массива
Нужно сделать в форме. Дана целочисленная матрица A(n x n). Все элементы тех столбцов, у которых обнаружено менее 10 положительных...

Заменить элементы столбца матрицы суммой элементов всех оставшихся столбцов
В положительной матрице имеется столбец,содержащий только единицы.Заменить элементы этого столбца суммой элементов всех оставшихся столбцов

3
 Аватар для DirectX
24 / 18 / 21
Регистрация: 07.10.2013
Сообщений: 47
19.09.2014, 04:17
Лучший ответ Сообщение было отмечено azotklas как решение

Решение

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
#include <iostream>
#include <cstdlib>
using namespace std;
 
int main(int argc, char const *argv[])
{
    const int SIZE = 3;
 
    // allocate memory for dynamic array
    int** arr = new int* [SIZE];
    for (int i = 0; i < SIZE; ++i)
        arr[i] = new int[SIZE];
 
    // input array
    for (int i = 0; i < SIZE; ++i)
        for (int j = 0; j < SIZE; ++j)
        {
            cout << "Enter arr[" << i + 1 << "][" << j + 1 << "]: ";
            cin >> arr[i][j];
        }
 
    int sum;
    bool flag;
    for (int j = 0; j < SIZE; ++j)
    {
        sum = 0;
        flag = false;
        for (int i = 0; i < SIZE; ++i)
        {
            if (arr[i][j] >= 0)
            {
                flag = true;
                break;
            }
 
            sum += arr[i][j];
        }
 
        if (!flag)
        {
            for (int i = 0; i < SIZE; ++i)
                arr[i][j] = sum;    
        }
    }
 
    // output array
    for (int i = 0; i < SIZE; ++i)
    {
        for (int j = 0; j < SIZE - 1; ++j)
            cout << arr[i][j] << ' ';
        cout << arr[i][SIZE - 1] << "\n";
    }
 
    // free memory for dynamic array
    for (int i = 0; i < SIZE; ++i)
        delete [] arr[i];
    delete [] arr;
 
    system("pause");
    return 0;
}
1
0 / 0 / 1
Регистрация: 16.09.2014
Сообщений: 26
19.09.2014, 19:03  [ТС]
почти, но не так! нужно заменить на сумму каждого числа. а вы сделали замену на сумму всех чисел!
то есть, например так:
массив:
1 -13 14
4 -67 67
2 -55 34

должно получиться так
1 4 14
4 13 67
2 10 34

а вы сделали так

1 -135 14
4 -135 67
2 -135 34

измените пожалуйста код!

Добавлено через 35 минут
вот готовый вариант))

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
#include <iostream>
#include <cstdlib>
using namespace std;
 
int main(int argc, char const *argv[])
{
/*
int SIZE;
cout«"Vvedite razmer massiva: ";
cin»SIZE;
 
 
int** arr = new int* [SIZE];
for (int i = 0; i < SIZE; ++i)
arr[i] = new int[SIZE];
 
 
for (int i = 0; i < SIZE; ++i)
for (int j = 0; j < SIZE; ++j)
{
cout « "Enter arr[" «i« "][" «j« "]: ";
cin » arr[i][j];
}*/
 
const int SIZE=4;
 
int arr[SIZE][SIZE]={{31,32,-45,32},
{65,34,-76,23},
{23,62,-12,45},
{23,51,-66,23}};
 
int sum,num;
bool flag;
for (int j = 0; j < SIZE; j++)
{
sum = 0;
flag = false;
for (int i = 0; i < SIZE; i++)
{
if (arr[i][j] >= 0)
{
flag = true;
break;
}
 
}
 
if (!flag)
{
for (int i = 0; i < SIZE; i++)
{
 
//arr[i][j] = sum;
 
num = arr[i][j];
while (num != 0) //нахожу сумму цифр
{
sum=sum+num%10;
num=num/10;
}
 
arr[i][j] = abs(sum);
sum = 0;
num = 0;
}
}
}
 
 
for (int i = 0; i < SIZE; i++)
{
for (int j = 0; j < SIZE-1; j++)
cout « arr[i][j] « ' ';
cout « arr[i][SIZE-1] « "\n";
}
// free memory for dynamic array
for (int i = 0; i < SIZE; ++i)
 
//delete (arr[][]);
//system("pause");
return 0;
}
0
19.09.2014, 19:38

Не по теме:

заменить суммой их цифр
невнимательно прочитал этот участок задания

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
19.09.2014, 19:38
Помогаю со студенческими работами здесь

Заменить отрицательные элементы матрицы суммой положительных элементов главной диагонали
Дана квадратная матрица размерностью m. Заменить отрицательные элементы матрицы суммой положительных элементов главной диагонали. ...

Все элементы матрицы (StringGrid) с наибольшим значением заменить суммой положительных элементов
Задача: В целочисленной матрице размера 4х5 все элементы с наибольшим значением заменить суммой положительных элементов. Чтобы...

Элементы столбцов матрицы, у которых менее 10 положительных элементов, заменить на элементы массива
Дана целочисленная матрица A(nxn). Все элементы тех столбцов, у которых обнаружено менее 10 положительных элементов, заменить на элементы...

Среди столбцов матрицы, содержащих только элементы в диапазоне от 0 до 10, найти столбец с максимальной суммой
Дана динамическая матрица размера N*M (N и M вводятся). Среди столбцов матрицы, содержащих только элементы в диапазоне от 0 до 10, найти...

Поиск количества столбцов матрицы, содержащих больше трех положительных элементов
Помогите пожалуйста с написанием кода. Дан двумерный массив, размерность массива и элементы вводятся вручную. Я не знаю как...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru