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

Объяснить что происходит в данном фрагменте кода (вложенные циклы и массивы)

03.12.2015, 02:25. Показов 991. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Объясните пожалуйста данный момент
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
for (int i = 1; i <= a; i++)
    {
        if (m[i] == 0)
        {
            c = i;
            while (m[c] == 0) c++;
            if (c>a) 
                c = a;
                m[i] = m[c];
                m[c] = 0;
        }
 
    }
в этой программе
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
#include <stdio.h>
#include <iostream>
using namespace std;
int main()
{
 
    int a = 0, c = 0, i;
    int m[101];
 
    setlocale(0, "");
 
    while (a <= 0 || a>100)
 
    {
        printf("Количество чисел (не больше 100): ");
        scanf_s("%d", &a);
        if (a>100 || a <= 0) printf("Некорректное число!\n");
    }
 
    for (i = 1; i <= a; i++)
 
    {
        printf("Введите элемент m[%d]: ", i);
        scanf_s("%d", &m[i]);
    }
 
    for (int i = 1; i <= a; i++)
    {
        if (m[i] == 0)
        {
            c = i;
            while (m[c] == 0) c++;
            if (c>a) 
                c = a;
                m[i] = m[c];
                m[c] = 0;
        }
 
    }
 
    printf("Сортированный массив:\n\n");
 
    for (int i = 1; i <= a; i++) 
        printf("%d ", m[i]);
 
    printf("\n\n");
    system("pause");
 
    return 0;
 
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.12.2015, 02:25
Ответы с готовыми решениями:

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

Объяснить, что происходит в заданном фрагменте кода
ifstream f(&quot;Базаданных.bd&quot;, ios::binary); f.read((char*)&amp;P,sizeof(P)); do { ...

Объяснить, что происходит в заданном фрагменте кода
В подпрограмме Всё предельно ясно кроме одной строки - P.year=y-'0'; Объясните недалёкому что происходит в строке { ...

9
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
03.12.2015, 04:45
Цитата Сообщение от Hjoky Посмотреть сообщение
Объясните пожалуйста данный момент
Сдвигает все нули в правую часть массива и потенциально вылетает за границы массива. Выход за границы массива подперт костыликом, но возможности "access violation память не может быть read" не исключает. То что массивы в C++ индексируются не с единицы как у вас, а с нуля это уже так, мелочи. Короче, не тому дружбану пивом проставились.
2
0 / 0 / 0
Регистрация: 27.11.2015
Сообщений: 21
03.12.2015, 17:36  [ТС]
а что вы имели в виду под "не тому дружбану пивом проставились."
0
2784 / 1937 / 570
Регистрация: 05.06.2014
Сообщений: 5,602
03.12.2015, 17:53
Цитата Сообщение от Hjoky Посмотреть сообщение
а что вы имели в виду под "не тому дружбану пивом проставились."
1) Не вы писали этот код. Иначе не спрашивали бы что он означает.
2) Вряд ли вы списали это из учебника. Я все же надеюсь что там такую дичь не пропускают.
Итого, остается вариант что код вам накатал друг, а вы ему за это пивом проставились.
0
0 / 0 / 0
Регистрация: 27.11.2015
Сообщений: 21
03.12.2015, 19:37  [ТС]
А вы можете исправить данный код?

Добавлено через 1 час 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
#include <iostream>
 
using namespace std;
 
int main()
{
    int n, c = 0;
    int a[100];
    setlocale(0, "");
    do
        {
            cout << "Введитек количество чисел: ";
            cin >> n;
            if ((n > 100) || (n < 2))
                cout << "Неверно, количество чисел должно быть меньше 100 и больше 2 \n";
        } 
    while ((n > 100) || (n < 2));
    cout << "Введите последовательность:\n";
    for (int i = 0; i < n; i++)
        {
            cout << "Введите элемент a" << i + 1 << " = ";
            cin >> a[i];
        }
    for (int i = 0; i < n - 1; i++)
        {
            if (a[i] == 0)
                {
                    c = i;
                    while (a[c] == 0)
                        {
                            c++;
                        }
                    if (c > n-1)
                        {
                            c = n-1;
                        }
                    a[i] = a[c];
                    a[c] = 0;
 
                }
        }
    cout << ("Сортированный массив:\n\n");
 
    for (int i = 0; i < n; i++)
    {
        cout << (a[i]) << "  ";
    }
    cout <<"\n"<< endl;
    system("pause");
}
0
0 / 0 / 0
Регистрация: 27.11.2015
Сообщений: 21
10.12.2015, 02:50  [ТС]
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
#include <iostream>
#include "conio.h"
#include <cstdlib>
 
using namespace std;
 
int main()
{
    system("color 02");
    int n, c = 0;
    int a[20];
    setlocale(0, "");
    do
        {
            cout << "Введитек количество чисел: ";
            cin >> n;
            if ((n > 20) || (n < 2))
                cout << "Неверно, количество чисел должно быть меньше 20 и больше 2 \n";
        } 
    while ((n > 20) || (n < 2));
    cout << "Введите последовательность:\n";
    for (int i = 0; i < n; i++)
        {
            cout << "Введите элемент a" << i + 1 << " = ";
            cin >> a[i];
        }
    for (int i = 0; i < n - 1; i++)
        {
            if (a[i]==0)
            {
                for (int j = i + 1; j < n; j++)
                {
                    if (a[j])
                    {
                        a[i] = a[j];
                        a[j] = 0;
                        j = n;
                    }
                }
            }
 
        }
    cout << ("Сортированный массив:\n\n");
 
    for (int i = 0; i < n; i++)
    {
        cout << (a[i]) << "  ";
    }
    cout << "\n" << endl;
    _getch();
    return 0;
}
0
0 / 0 / 0
Регистрация: 27.11.2015
Сообщений: 21
19.12.2015, 02:14  [ТС]
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
#include "stdafx.h"
#include "stdio.h"
#include "conio.h"
#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
 
int main()
{
    int n;
    int a[100][100];
    setlocale(0, "");
    //Защита от дураков
    do
    {
        printf("Введите размерность матрицы: ");
        scanf_s("%d", &n); //Ввод размерности матрицы - n
        if ((n > 20) || (n < 2))
            printf("Неверно, количество чисел должно быть меньше 20 и больше 2 \n");
    } while ((n > 20) || (n < 2));
 
    //Ввод матрицы A
    srand(time(NULL));
    printf("Матрица А:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            a[i][j] = rand() % 198 -99; // Каждый элемент случайному числу от -99 до 99
            printf("%d%c", a[i][j], '  '); // Вывести элементы на консольку
        }
        printf("\n"); // Двумерный массив. Строка кончилась, переводим строку и на консоли
    }
 
    //Получем матрицу C   
    for (int i = 0; i < n; i++)
    for (int j = 0; j < i; j++)
        a[i][j] = a[j][i];
 
    //Вывод на экран матрицы С
    printf("Матрица C:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            printf("%d%c", a[i][j], '  ');
        printf("\n");
    }
 
    //Получем матрицу B
    for (int i = 0; i < n; i++)
    for (int j = 0; j < n; j++)
    if (i != j)
    {
        a[i][i] += a[j][i];
        a[j][i] = 0;
    }
 
    //Ищем след матрицы  B
    int trace = 0;
    for (int i = 0; i < n; i++)
        trace += a[i][i];
 
    //Вывод на экран матрицы B
    printf("Матрица B:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            printf("%d%c", a[i][j], '  ');
        printf("\n");
    }
 
    //Вывод на экран следа матрицы B
    printf("%s%d", "След матрицы B = ", trace);
    printf("\n");
 
    _getch();
    return 0;
}
0
0 / 0 / 0
Регистрация: 27.11.2015
Сообщений: 21
24.12.2015, 23:18  [ТС]
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
#include "stdafx.h"
#include "stdio.h"
#include "conio.h"
#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
 
int main()
{
    int n, k, l, m, g;
    int a[100][100];
    int v[100];
    system("color f0");
    setlocale(0, "");
    //Защита от дураков
    do
    {
        printf("Введите размерность матрицы: ");
        scanf_s("%d", &n); //Ввод размерности матрицы - n
        if ((n > 20) || (n < 2))
            printf("Неверно, количество чисел должно быть меньше 20 и больше 2 \n");
    } while ((n > 20) || (n < 2));
 
    //Ввод матрицы A
    srand(time(NULL));
    printf("Матрица А:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            a[i][j] = rand() % 198 - 99; // Каждый элемент случайному числу от -99 до 99
            printf("%d%c", a[i][j], '  '); // Вывести элементы на консольку
        }
        printf("\n"); // Двумерный массив. Строка кончилась, переводим строку и на консоли
    }
    printf("\n");
 
    //Получем матрицу C   
    for (int i = 0; i < n; i++)
    {
        a[i][i] = 0;
        for (int j = 0; j < n; j++)
        {
            a[i][j] = a[j][i] * -1;
        }
    }
 
    //Вывод на экран матрицы С
    printf("Матрица C:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            printf("%d%c", a[i][j], '  ');
        printf("\n");
    }
    printf("\n");
 
    // ввод первой строки
    printf("%s%d", "Введите номер первого столбца от 1 до ", n);
    printf("\n");
    scanf_s("%d", &k);
    k = k - 1;
 
    // ввод второй строки
    printf("%s%d", "Введите номер второго столбца от 1 до ", n);
    printf("\n");
    scanf_s("%d", &l);
    l = l - 1;
 
    // получение переработанной матрицы c
    printf("\n");
    for (int j = 0; j < n; j++)
    {
        m = a[j][k];
        a[j][k] = a[j][l];
        a[j][l] = m;
    }
 
    // вывод матрицы А
    printf("Матрица C после обработки:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            printf("%d%c", a[i][j], '  ');
        printf("\n");
    }
    printf("\n");
 
    // Получаем вектор
    g = 0;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        if (i >= j)
        {
            v[g] = a[i][j];
            g++;
        }
    }
 
    // Выводим вектор
    printf("вектор:\n");
    for (int i = 0; i < g; i++)
        printf("%d%c", v[i], '  ');
    _getch();
    return 0;
}
0
 Аватар для anti-k
227 / 75 / 31
Регистрация: 17.07.2015
Сообщений: 774
24.12.2015, 23:20
Hjoky, Вы можете написать условие задачи?
0
0 / 0 / 0
Регистрация: 27.11.2015
Сообщений: 21
25.12.2015, 03:33  [ТС]
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
#include "stdafx.h"
#include "stdio.h"
#include "conio.h"
#include <iostream>
#include <ctime>
#include <cstdlib>
using namespace std;
 
int main()
{
    int n, k, l, m, g;
    int a[100][100];
    int v[100];
    system("color f0");
    setlocale(0, "");
    //Защита от дураков
    do
    {
        printf("Введите размерность матрицы: ");
        scanf_s("%d", &n); //Ввод размерности матрицы - n
        if ((n > 20) || (n < 2))
            printf("Неверно, количество чисел должно быть меньше 20 и больше 2 \n");
    } while ((n > 20) || (n < 2));
 
    //Ввод матрицы A
    srand(time(NULL));
    printf("Матрица А:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            a[i][j] = rand() % 198 - 99; // Каждый элемент случайному числу от -99 до 99
            printf("%d%c", a[i][j], '  '); // Вывести элементы на консольку
        }
        printf("\n"); // Двумерный массив. Строка кончилась, переводим строку и на консоли
    }
    printf("\n");
 
    //Получем матрицу C   
    for (int i = 0; i < n; i++)
    {
        a[i][i] = 0;
        for (int j = 0; j < n; j++)
        {
            a[i][j] = a[j][i] * -1;
        }
    }
 
    //Вывод на экран матрицы С
    printf("Матрица C:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            printf("%d%c", a[i][j], '  ');
        printf("\n");
    }
    printf("\n");
 
    do
    {
        printf("%s%d", "Введите номер певго столбца от 1 до ", n);
        printf("\n");
        scanf_s("%d", &k);
        printf("%s%d", "Введите номер второго столбца от 1 до ", n);
        printf("\n");
        scanf_s("%d", &l);
        if ((k > n) || (k < 1) || (l > n) || (l < 1))
        {
            printf("%s%d", "Неверно, номеа столбцов должны быть меньше ", n);
            printf(" и больше 0 \n\n");
        }
    } 
    while ((k > n) || (k < 1) || (l > n) || (l < 1));
 
    k = k - 1;
    l = l - 1;
 
    // получение переработанной матрицы c
    printf("\n");
    for (int j = 0; j < n; j++)
    {
        m = a[j][k];
        a[j][k] = a[j][l];
        a[j][l] = m;
    }
 
    // вывод матрицы А
    printf("Матрица C после обработки:\n");
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
            printf("%d%c", a[i][j], '  ');
        printf("\n");
    }
    printf("\n");
 
    // Получаем вектор
    g = 0;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        if (i >= j)
        {
            v[g] = a[i][j];
            g++;
        }
    }
 
    // Выводим вектор
    printf("вектор:\n");
    for (int i = 0; i < g; i++)
        printf("%d%c", v[i], '  ');
    _getch();
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
25.12.2015, 03:33
Помогаю со студенческими работами здесь

Объяснить, что происходит в коде (вложенные циклы)
Добрый день, вот моя программа, точнее взятая у кого-то и немного переделана, но всё равно не работает. не могли бы вы мне объяснить мои...

Подробно расписать что происходит в данном фрагменте кода
Int() :intez(0) {} Int(int intz) :intez(intz) {} распишите плиз, что где и зачем

Списки: объяснить, что происходит в заданном фрагменте кода
Помогите разобраться в коде, вот код с# public class Node { public string Data { get; set; } public Node...

Объяснить, что происходит в заданном фрагменте кода (шифр Цезаря)
#include &lt;iostream&gt; #include &lt;string&gt; #include &lt;conio.h&gt; #include &lt;stdlib.h&gt; #include &lt;sstream&gt; #include &lt;fstream&gt; using...

Нюансы работы с указателями: объяснить, что происходит в заданном фрагменте кода
Всем доброго времени суток! Я не до конца разобрался в данной теме. К примеру, есть такой кусок программы: ... int N; int...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru