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

Пропадают элементы массива

19.11.2019, 22:45. Показов 1929. Ответов 6

Студворк — интернет-сервис помощи студентам
Задали в универе написать шифровальщик ADFGX https://ru.wikipedia.org/wiki/... %80_ADFGVX
Вот такой код получился:
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
#include <iostream>
#include <conio.h>
#include <windows.h>
#include <cstdlib>
using namespace std;
int main() {
    char a[6][6];
    a[1][1]=' ';
    a[1][2]='A';
    a[1][3]='D';
    a[1][4]='F';
    a[1][5]='G';
    a[1][6]='X';
    a[2][1]='A';
    a[3][1]='D';
    a[4][1]='F';
    a[5][1]='G';
    a[6][1]='X';
    HANDLE hCon;
    COORD cPos;
    hCon = GetStdHandle(STD_OUTPUT_HANDLE);
    int x=0, j=1;
    int y=2, i=2;
    for(;x<=20;x=x+4, j++) {
        cPos.X=x;
        cPos.Y=0;
        SetConsoleCursorPosition(hCon, cPos);
        cout<<a[1][j];
    }
    for(;y<=10;y=y+2, i++) {
        cPos.X=0;
        cPos.Y=y;
        SetConsoleCursorPosition(hCon, cPos);
        cout<<a[i][1];
    }
    char c[25];
    int n=1;
    int l;
    for(y=2, i=2;y<=10;y=y+2, i++) {
        for(x=4, j=2;x<=20;x=x+4, j++){
            start:
            cPos.X=x;
            cPos.Y=y;
            SetConsoleCursorPosition(hCon, cPos);
            cin>>a[i][j];
            c[n]=a[i][j];
            for(l=0;l<=n-1;l++) {
                if(c[n]==c[l]) {
                    cout<<"Wrong";
                    goto start;
                }
            }
            n++;
            cout<<"     ";
        }
    }
    char b[100];
    char d[100];
    for(n=0;n<=99;n++) {
        d[n]='\0';
    }
    cout<<endl<<"Message without spaces: ";
    cin>>b;
    for(l=0;b[l];l++) {
        for(i=2;i<=6;i++) {
            for(j=2;j<=6;j++) {
                if(b[l]==a[i][j]) {
                    d[2*l]=a[i][1];
                    d[2*l+1]=a[1][j];
                }
            }
        }
    }
    cout<<d;
    char e[100];
    reenter:
    for(n=0;n<=99;n++) {
        e[n]='\0';
    }
    cout<<endl<<"Enter key: ";
    cin>>e;
    for(n=0;e[n];n++) {
    }
    if(l%n!=0) {
        cout<<"Invalid key length, re-enter";
        goto reenter;
    }
    const int q=(2*l+n)/n;
    char f[q][n];
    for(j=1;j<=n;j++) {
        f[1][j]=e[j-1];
    }
    int k=0;
    for(i=2;i<=q;i++) {
        for(j=1;j<=n;j++) {
            f[i][j]=d[k];
            k++;
        }
    }
    for(i=1;i<=q;i++) {
        for(j=1;j<=n;j++) {
            cout<<f[i][j]<<"  ";
        }
        cout<<endl;
    }
    cout<<endl;
    char g[q][1];
    for(i=1;i<n;i++) {
        for(j=i+1;j<=n;j++) {
            if((int)(f[1][i])>(int)(f[1][j])) {
                for(k=1;k<=q;k++) {
                    g[k][1]=f[k][i];
                }
                for(k=1;k<=q;k++) {
                    f[k][i]=f[k][j];
                }
                for(k=1;k<=q;k++) {
                    f[k][j]=g[k][1];
                }
            }
        }
    }
    for(i=1;i<=q;i++) {
        for(j=1;j<=n;j++) {
            cout<<f[i][j]<<"  ";
        }
        cout<<endl;
    }
    system("pause>nul");
    return 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
#include <iostream>
using namespace std;
int main() {
    int q=5;
    char g[q][1];
    int n=6;
    int k;
    int i,j;
    char f[5][6];
    for (i=1;i<=q;i++) {
        for(j=1;j<=n;j++) {
            cin>>f[i][j];
        }
    }
    for(i=0;i<=q;i++) {
        for(j=1;j<=n;j++) {
            cout<<f[i][j];
        }
        cout<<endl;
    }
    for(i=1;i<n;i++) {
        for(j=i+1;j<=n;j++) {
            if((int)(f[1][i])>(int)(f[1][j])) {
                for(k=1;k<=q;k++) {
                    g[k][1]=f[k][i];
                }
                for(k=1;k<=q;k++) {
                    f[k][i]=f[k][j];
                }
                for(k=1;k<=q;k++) {
                    f[k][j]=g[k][1];
                }
            }
        }
    }
    for(i=1;i<=q;i++) {
        for(j=1;j<=n;j++) {
            cout<<f[i][j]<<"  ";
        }
        cout<<endl;
    }
}

В чем может быть проблема?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
19.11.2019, 22:45
Ответы с готовыми решениями:

Пропадают элементы формы при работе на другом компьютере
Доброго времени суток! Писал программу для редактирования кривых (зачётное задание в универе). Для визуализации воспользовался OpenGL....

Найти максимальный и минимальный элементы массива из четных. Удалить их из массива
Добрый день ! Уважаемые знатоки ! Помогите пожалуйста дописать программу ... Задание ! Дан массив. Найти максимальное число из четных...

Из массива в массив перенести числа (элементы массива)
Из массива JJ(100) в массив NN(100) перенести числа (элементы массива) сначала нечетные, а затем четные. Вывести массив NN на печать по 10...

6
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.11.2019, 09:41
Лучший ответ Сообщение было отмечено OpenRange179 как решение

Решение

Цитата Сообщение от OpenRange179 Посмотреть сообщение
Проблема с выводом в самом конце:
Думаю, проблема в нестрогих сравнениях, типа for(j=1;j<=n;j++). Зачем ты их используешь?
вот здесь, например
Цитата Сообщение от OpenRange179 Посмотреть сообщение
for(i=1;i<=q;i++) {
        for(j=1;j<=n;j++) {
            cout<<f[i][j]<<"  ";
У тебя массив объявлен как char f[q][n];, надо, наверное, делать i < q и j < n
1
0 / 0 / 0
Регистрация: 19.11.2019
Сообщений: 4
20.11.2019, 17:49  [ТС]
У меня просто изначально первый элемент был с индексом 1, а не 0, поэтому сравнение нестрогое. Это не влияет на результат.
0
6772 / 4565 / 1844
Регистрация: 07.05.2019
Сообщений: 13,726
20.11.2019, 17:51
Цитата Сообщение от OpenRange179 Посмотреть сообщение
У меня просто изначально первый элемент был с индексом 1, а не 0, поэтому сравнение нестрогое. Это не влияет на результат.
При i == q или j ==n будет выход за границу массива
1
0 / 0 / 0
Регистрация: 19.11.2019
Сообщений: 4
20.11.2019, 17:59  [ТС]
Хорошо, но во втором листинге у меня выход за границу массива, и при этом все работает как нужно.
0
фрилансер
 Аватар для Алексей1153
6464 / 5676 / 1131
Регистрация: 11.10.2019
Сообщений: 15,117
20.11.2019, 18:05
OpenRange179, выход за границу - это уже не как нужно. Его не должно быть
1
0 / 0 / 0
Регистрация: 19.11.2019
Сообщений: 4
20.11.2019, 18:24  [ТС]
Спасибо! Убрал выход за границу массива, все заработало.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.11.2019, 18:24
Помогаю со студенческими работами здесь

Пропадают элементы из матрицы
Такая вот проблема, считываю матрицу с текстового файла, по мере считывания вывожу каждый элемент матрицы - все элементы присутствуют....

Сформируйте третий массив, в котором в начале расположены элементы первого массива, а затем элементы второго массива
Даны два целочисленных массива. Сформируйте третий массив, в котором в начале расположены элементы первого массива, а затем элементы...

Создать два новых массива, в один из которых поместить положительные элементы массива, а в другой отрицательные и нулевые элементы
Написать программу , которая вводит с клавиатуры массив из N вещественных чисел , создает два новых массива , в один из которых помещает...

Получить третий массив C[15] по правилу: вначале элементы первого массива, затем элементы второго массива
Даны массивы A, B. Нужно получить третьи массив C состоящий: вначале элементы первого массива, затем элементы второго массива.

Вывести элементы массива на промежутке [ a,b ], вычислить количество элементов массива, заменить все положительные элементы
В одномерном массиве, состоящем из n вещественных элементов, – вывести на печать элементы массива, значения которых не принадлежат...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru