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

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

25.11.2019, 18:37. Показов 4678. Ответов 34

Студворк — интернет-сервис помощи студентам
Добрый день. Помогите пожалуйста решить задачу по программированию, сам не очень разбираюсь в нем.
Задать A и B как параметры функции:
а) сформировать двумерный массив из:
- произведений элементов четных столбцов исходной матрицы a,
находящихся в пределах: A < a [i] [j] <=B - (первая строка нового массива);
- количества таких элементов в каждом столбце - (вторая строка нового
массива);

б) определить сумму произведений сформированного массива и общее
количество таких элементов столбцов;

в) определить максимальное и минимальное значения произведений и
поменять местами столбцы исходной матрицы, в которых они найдены, если
номера столбцов разные.

 Комментарий модератора 
П.5.16.Правил
Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.


Помогите найти ошибки и исправить код.Буду благодарен тому, кто возьмется за эту задачку)
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
void obr(float a[m][n], float b[2][(m + 1) / 2], int A, int B)
{
    double pr = 1, min, max, r;
    int kol = 0, pmin = 0, pmax = 0;
    int i, j, k; //k -переменная для подсчета количества нужных элементов
    float proiz; //переменная для подсчета произведения
    for (i = 0; i < m; i ++) 
    {
        proiz=1; 
        k = 0; 
        for (j = 1; j < n; j+=2) 
            if ((A <= a[i][j]) && (a[i][j] < B)) 
            {
                proiz *= a[i][j]; 
                k++; 
            }
        if (k == 0)
        {
            b[0][i / 2] = 0; 
            b[1][i / 2] = 0;
        } 
        else { 
            b[0][i / 2] = proiz;
        b[1][i / 2] = k; } 
    }
    min = b[0][0];
    max = b[0][0];
    for (i = 0; i < (m + 1) / 2; i++) 
    { if (b[0][i] < min) 
    { 
        pmax = i; 
        min = b[0][i]; 
    } 
    if (b[0][i] > max) 
    {
        pmin = i; 
        max = b[0][i]; 
    } 
    if (b[1][i] != 0) 
        pr *= b[0][i];
    }
    for (i = 0; i < (m + 1) / 2; i++)
    { 
        kol += b[1][i];
    }
    if (pmax != pmin) 
        for (i = 0; i < n;i++) {
        r = a[pmin * 2][i]; 
        a[pmin * 2][i] = a[pmax * 2][i]; 
        a[pmax * 2][i] = r;
    }
    fout << "Maks proizvedenie" << max << endl << "Min proizvedenie=" << min << endl << "Summa proizvedeniya=" << pr << endl << "Общее количество=" << kol << endl;
}
Добавлено через 7 минут
Пункт а) у меня сделать, в приоритете сделать б и в
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.11.2019, 18:37
Ответы с готовыми решениями:

Сформировать матрицу-строку из максимальных элементов столбцов исходной матрицы
Дана матрица К размера n*m, где n,m&lt;=15. Элементы матрицы- случайные числа из диапозона . Написать процедуру, которая формирует матрицу-...

Вернуть матрицу из элементов матрицы М, находящихся одновременно в чётных строках и чётных столбцах
Помогите плз с заданием Напишите функцию func, которая принимает на вход матрицу M и возвращает матрицу из элементов матрицы М,...

Сформировать массив из произведений положительных элементов соответствующих столбцов матрицы
Дан целочисленный массив А. Сформировать одномерный массив В из произведений положительных элементов соответствующих столбцов массива А. ...

34
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
25.11.2019, 18:47  [ТС]
Добрый день. Помогите пожалуйста решить задачу по программированию, сам не очень разбираюсь в нем.
Задать A и B как параметры функции:
а) сформировать двумерный массив из:
- произведений элементов четных столбцов исходной матрицы a,
находящихся в пределах: A < a [i] [j] <=B - (первая строка нового массива);
- количества таких элементов в каждом столбце - (вторая строка нового
массива);
Я написал код , но он выводит только один элемент
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
void obr(float a[m][n], float b[2][(m + 1) / 2], int A, int B)
{
    double pr = 1, min, max, r;
    int kol = 0, pmin = 0, pmax = 0;
    int i, j, k; //k -переменная для подсчета количества нужных элементов
    float proiz; //переменная для подсчета произведения
    for (i = 0; i < m; i ++) 
    {
        proiz=1; 
        k = 0; 
        for (j = 1; j < n; j+=2) 
            if ((A <= a[i][j]) && (a[i][j] < B)) 
            {
                proiz *= a[i][j]; 
                k++; 
            }
        if (k == 0)
        {
            b[0][i / 2] = 0; 
            b[1][i / 2] = 0;
        } 
        else { 
            b[0][i / 2] = proiz;
        b[1][i / 2] = k; } 
    }
 }
0
 Аватар для FFPowerMan
2159 / 1239 / 509
Регистрация: 11.10.2018
Сообщений: 6,287
25.11.2019, 18:53
Цитата Сообщение от overmouseee Посмотреть сообщение
C++
1
void obr(float a[m][n], float b[2][(m + 1) / 2], int A, int B)
- вот так матрицы в функцию не передаются. Одним из способов является передача адреса на первый элемент(просто имя массива) и число элементов в массиве. Там, в памяти, они(элементы массива) уже упорядочены как надо.
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
25.11.2019, 18:58  [ТС]
В универе говорят,что на этой лабе так делать нужно
0
 Аватар для FFPowerMan
2159 / 1239 / 509
Регистрация: 11.10.2018
Сообщений: 6,287
25.11.2019, 19:08
Зачем вообще в функции писать - все сделайте в main да и все.

Добавлено через 34 секунды
А, m и n - это константы?

Добавлено через 55 секунд
Цитата Сообщение от overmouseee Посмотреть сообщение
В универе говорят,что на этой лабе так делать нужно.
- Ну я не знаю, я бы так сделал как я сказал. А во 2 массиве 2 строчки?
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
25.11.2019, 19:09  [ТС]
Да,массив 5 на 6,т.е m=5 , n=6. Две строки в новом массиве - первая произведение элементов четных столбцов, а вторая строка соответственно кол-во этих элементов. obr(a, b, 3, 5); //3, 5 -границы интервала значений нужных элементов
0
 Аватар для FFPowerMan
2159 / 1239 / 509
Регистрация: 11.10.2018
Сообщений: 6,287
25.11.2019, 19:28
Я так полагаю, что компилятор скопирует эти массивы в функцию, что не очень хорошо. Поэтому надо передавать по ссылке, т.е. поставить перед именем массива во входных аргументах функции знак "&".
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
25.11.2019, 19:30  [ТС]
Дело в том, что я вывожу данные из файла и через эту программу он заного заносится в файл. Это работает, но не работает новый массив, где нужно произведение и количество. Он берет только первое значение и кол-во пишет 1, когда элемента 2 или 3
0
 Аватар для FFPowerMan
2159 / 1239 / 509
Регистрация: 11.10.2018
Сообщений: 6,287
25.11.2019, 20:01
Вот так должна быть 1-ая строка функции
C++
1
void obr(float (*a)[n], float (*b)[(m + 1) / 2], int A, int B)
Добавлено через 10 минут
Цитата Сообщение от overmouseee Посмотреть сообщение
C++
1
for(j = 1;
- кто этот бред писал? Разве четные от 1 начинаются, от 0.

Добавлено через 2 минуты
C++
1
if((A <= a[i][j]) && (a[i][j] < B))
- в условии написано наоборот.
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
25.11.2019, 20:04  [ТС]
Ну у меня таблица, и поэтому я сделал j=1 чтобы в таблице со 2 столбика начиналось
0
 Аватар для FFPowerMan
2159 / 1239 / 509
Регистрация: 11.10.2018
Сообщений: 6,287
25.11.2019, 20:26
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
#include <iostream>
#include <cstdlib>
#include <iomanip>
using namespace std;
#define m 5
#define n 6
 
float Mas[m][n], Vih[2][(n + 1) / 2] = {0};
 
void obr(float (*a)[n], float (*b)[(n + 1) / 2], int A, int B)
{
    double proiz;       //переменная для подсчета произведения
    int kol = 0, Row, Col, k;    //k -переменная для подсчета количества нужных элементов
 
    for(Col = 0; Col < n; Col += 2)
    {
        proiz = 1;
        k = 0;
        for(Row = 0; Row < m; Row ++)
            if((A < a[Row][Col]) && (a[Row][Col] <= B))
            {
                proiz *= a[Row][Col];
                k++;
            }
        if(k == 0)
        {
            b[0][Col/2] = 0;
            b[1][Col/2] = 0;
        }
        else
        {
            b[0][Col/2] = proiz;
            b[1][Col/2] = k;
        }
    }
}
 
int main()
{
    int Str, Stl;
 
    cout << "Mas:\n";
    for(Str = 0; Str < m; Str++)
    {
        for(Stl = 0; Stl < n; Stl++)
        {
            Mas[Str][Stl] = rand()%10;
            cout << setw(5) << Mas[Str][Stl] << " ";
        }
        cout << "\n";
    }
 
    obr(Mas, Vih, 5, 8);
    cout << "\n\nVih:\n";
    for(Str = 0; Str < 2; Str++)
    {
        for(Stl = 0; Stl < (m+1)/2; Stl++)
        {
            cout << setw(5) << Vih[Str][Stl] << " ";
        }
        cout << "\n";
    }
    return 0;
}
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
25.11.2019, 20:54  [ТС]
Так тут же четные строки ,а не столбцы
0
 Аватар для FFPowerMan
2159 / 1239 / 509
Регистрация: 11.10.2018
Сообщений: 6,287
26.11.2019, 11:22
Цитата Сообщение от FFPowerMan Посмотреть сообщение
C++
1
for(Col = 0; Col < n; Col += 2)
Цитата Сообщение от FFPowerMan Посмотреть сообщение
C++
1
a[Row][Col]
- где ты вилишь четные строки!!!!!!!!!!!! Иди учись дальше!!!!!!!!!!!!
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
26.11.2019, 16:53
overmouseee, правильно у Вас что начинаете цикл с 1. столбцы считаются так: первый, второй, третий...
чётные: второй, четвёртый, шестой... их индексы: 1,3,5...

у меня такой к Вам вопрос, что записывается в новый массив вместо произведения если в чётном столбце нет элементов из интервала (A,B] ?
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
26.11.2019, 18:21  [ТС]
Записываются нули где произведение и количество,если таких элементов нет
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
26.11.2019, 19:10
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
#include <iostream>
#include <cstdlib>
#include <ctime>
using namespace std;
 
double** Create (double **a, int n, int m, double A, double B)
{
    double **b = new double*[2], mult; 
    for (int i = 0; i < 2; i++)
       b[i]=new double[m/2];
    
    int count;   
    for (int j = 1; j < m; j+=2)
    {
        count=0;
        mult=1.;
        for (int i = 0; i < n; i++)     
        if (a[i][j]>A && a[i][j]<=B) {count++;mult*=a[i][j];}   
    if (count) b[0][j/2]=mult;
    else mult=0.;
    b[1][j/2]=(double)count;
    }
    return b;
}  
 
void Print (double **x, int N, int M)
{
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < M; j++)     
        cout << x[i][j] << " ";     
    cout << "\n";
    }
}    
 
int main()
{
    srand((int)time(0));
    int n, m;
    cout << "n="; cin >> n;
    cout << "m="; cin >> m;
    
      double **a = new double*[n], A, B, **b; 
    for (int i = 0; i < n; i++)
       a[i]=new double[m];   
    
    for (int i = 0; i < n; i++)    
        for (int j = 0; j < m; j++)     
        a[i][j]=rand()%9 + 1;
        
    cout << "Matrix a:\n";
    Print (a,n,m);   
       
    cout << "A="; cin >> A;
    cout << "B="; cin >> B;     
    
    b=Create (a,n,m,A,B);
    
    cout << "Matrix b:\n";    
    Print (b,2,m/2);          
    
    for (int i = 0; i < n; i++)
    delete[]a[i];
    delete[]a;
    for (int i = 0; i < 2; i++)
    delete[]b[i];
    delete[]b;
system("pause");
return 0;
}
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
28.11.2019, 19:17  [ТС]
Нужно найти ошибку.Вот задание:определить максимальное и минимальное значения произведений и поменять местами столбцы исходной матрицы, в которых они найдены, если номера столбцов разные . Заранее спасибо)
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
void obr(float a[m][n], float b[2][(n + 1) / 2], int A, int B)
{
    int i, j, k, kol, pmin = 1, pmax = 1;
    double r;
    float pr, sum, min, max;
    for (j = 1; j < n; j += 2)
    {
        pr = 1;
        k = 0;
        for (int i = 0; i < m; i++)
            if (a[i][j] > A&& a[i][j] <= B)
            {
                k++;
                pr *= a[i][j];
            }
        if (k) b[0][j / 2] = pr;
        else pr = 0;
        b[1][j / 2] = k;
    }
    kol = 0;
    sum = 0;
    for (i = 0; i < (m + 1) / 2; i++) {
 
        kol += b[1][i];
        sum += b[0][i];
    }
    min = b[0][0];
    max = b[0][0];
for (j = 0; j < (m + 1) / 2; j++)
    {
        if (b[0][j] < min)
        {
            pmax = j;
            min = b[0][j];
        }
        if (b[0][j] > max)
        {
            pmin = j; max = b[0][j];
        }
    }
if (smax != smin) а дальше не знаю что писать
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
30.11.2019, 11:11  [ТС]
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
#include <iostream>
#include <fstream>
#include <iomanip>
#include<conio.h>
#include<windows.h>
using namespace std;
const int m = 5, n = 6;
ifstream fin;
ofstream fout;
char c[6][256];
void main()
{
    fin.open("D:\ish.txt");
    if (!fin) { cout << "Ошибка при открытии файла данных"; exit(0); }
    fout.open("D:\pes.txt");
    if (!fout) { cout << "Ошибка при открытии файла результатов"; exit(0); }
    float a[m][n];
    float b[2][(m + 1) / 2];
    int i, j;
    void vvod(float a[m][n]);
    void p(float a[m][n]);
    void obr(float a[m][n], float b[2][(m + 1) / 2], int A, int B);
    vvod(a);
    p(a);
    obr(a, b, 1, 9); 
    fout << "\n\n\nNew array:";
    for (i = 0; i < 2; i++)
    {
        fout << '\n';
        for (j = 0; j < (n + 1) / 2; j++)
            fout << setw(12) << b[i][j];
 
    }
    fout.close();
}
 
void vvod(float a[m][n])
{
    int i, j;
    for (i = 0; i < 6; i++)
    {
        fin.getline(c[i], 182, '\n');
        if (i < 4) fout << c[i] << endl;
    }
    for (i = 0; i < m; i++)
        for (j = 0; j < n; j++)
            fin >> *(*(a + i) + j);
    fin.close();
}
void p(float a[m][n])
{
    int i, j;
    for (i = 0; i < m; i++)
    {
        fout << '|';
        for (j = 0; j < n; j++)
            switch (j)
            {
            case 0: case 1: case 3:case 4:
                fout.unsetf(ios::scientific);
                fout.width(10);
                fout.setf(ios::left | ios::fixed);
                fout.precision(5);
                fout << a[i][j] << '|';
                break;
            case 2:
                fout.width(10);
                fout.unsetf(ios::fixed);
                fout.setf(ios::scientific);
                fout.precision(4);
                fout << a[i][j] << '|';
                break;
            case 5:
                fout.width(10);
                fout.precision(4);
                fout << a[i][j] << "|\n";
                break;
            }
        if (i == m - 1) fout << c[5] << endl;
        else fout << c[4] << endl;
    }
}
void obr(float a[m][n], float b[2][(n + 1) / 2], int A, int B)
{
    int i, j, k, kol, prmin = 1, prmax = 1;
    double temp;
    float pr, sum, min, max;
    for (j = 1; j < n; j += 2)
    {
        pr = 1;
        k = 0;
        for (i = 0; i < m; i++)
            if (a[i][j] > A&& a[i][j] <= B)
            {
                k++;
                pr *= a[i][j];
            }
        if (k)
        {
            b[0][j / 2] = pr;
            b[1][j / 2] = k;
        }
        else pr = 0;
    }
    kol = 0;
    sum = 0;
    for (j = 0; j < (m + 1) / 2; j++) {
 
        kol += b[1][j];
        sum += b[0][j];
    }
    min = b[0][0];
    max = b[0][0];
    for (j = 0; j < (n + 1) / 2; j++)
    {
        if (b[0][j] < min)
        {
            prmax = j;
            min = b[0][j];
        }
        if (b[0][j] > max)
        {
            prmin = j; 
            max = b[0][j];
        }
    }
    for (j = 0; j < 6; j++)
    {
        temp = a[j][prmin * 2];
        a[j][prmin * 2] = a[j][prmax * 2];
        a[j][prmax * 2] = temp;
    }
    fout << endl << "=================Old array after change:================" << endl<<endl;
    p(a);
    fout << endl << " Obshee kol-vo elementov: " << kol << endl << "Summa proizvedeniya: " << sum << endl;
}
0
фрилансер
 Аватар для Алексей1153
6472 / 5687 / 1131
Регистрация: 11.10.2019
Сообщений: 15,167
30.11.2019, 11:26
overmouseee, так в какой строке вылетает то?

Кстати, в 13 и 15 строках не экранирован бэкслеш
0
0 / 0 / 0
Регистрация: 07.11.2019
Сообщений: 32
30.11.2019, 11:40  [ТС]
Не знаю, вот что выскакивает
Миниатюры
Сформировать матрицу из произведений элементов четных столбцов исходной матрицы находящихся в заданных пределах  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
30.11.2019, 11:40
Помогаю со студенческими работами здесь

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

Сформировать одномерный массив из произведений четных положительных элементов соответствующего столбца матрицы
1) Дан двумерный массив размерностью 5х6, заполненный целыми числами с клавиатуры. Сформировать одномерный массив, каждый элемент...

Сформировать одномерный массив, состоящий из произведений отрицательных элементов четных строк матрицы
Помогите, я сделала программу на делфи - работает, переделала на си не работает, помогите что бы выводилось.. ЗАДАНИЕ: Сформировать...

Сформировать матрицу из максимальных элементов области исходной матрицы
Из данной A составьте B матрицу (2 ≤ n ≤100) . B элемент равен  максимальному элементу матрицы A , который справа ограничен диагональю...

Сформировать матрицу C (), элементы которой равны квадратам соответствующих элементов исходной матрицы
Ввести значение переменной n. Ввести значение m. Ввести матрицу А (),в которой количество строк, а m -столбцов Сформировать матрицу...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru