С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++ Builder
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/15: Рейтинг темы: голосов - 15, средняя оценка - 5.00
Kisellev

Удаление одинаковых строк двумерного массива

13.06.2011, 22:18. Показов 3042. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброе время суток дамы и господа.
сижу в С++ Builder'e 6,
имеется массив чисел otvetibuff
110000...000
110000...000
110000...000
110000...000
110000...000
101000...000
000000...000
.................
000000...000
надо из него надо получить
110000...000
101000...000
000000...000
.................
000000...000

т.е. по сути оставить по одному экземпляру повторяющихся строк

информацию несут лишь левый верхний угол массива
написал код:
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
for (int i=0;i<=newni;i++)
        {
                for (int k=i+1;k<=newni;k++)
                {
                        int schet=0;
                        for (int j=0;j<=newnj;j++)
                        {
                                if (otvetibuff[i][j]==otvetibuff[k][j])
                                        {
                                                schet=schet+1;
                                        }
                        }
                        if (schet==newnj+1)
                                {
                                        for (int ii=i;ii<=newni;ii++)
                                                {
                                                        for (int jj=0;jj<=newnj;jj++)
                                                                {
                                                                        otvetibuff[ii][jj]=otvetibuff[ii+1][jj];
                                                                }
                                                }
                                }
                }
        }
где newnj = (количество столбцов-1) = 2
где newni = (количество строк-1) = 5
в данном случае.
в итоге получаю массив
110000...000
110000...000
101000...000
000000...000
.................
000000...000

При этом если массив будет заполнен неповторяющимися строками, он не должен измениться..
Помогите плиз, сижу пол дня, не найду косяк, голова не варит уже..
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.06.2011, 22:18
Ответы с готовыми решениями:

Удаление одинаковых строк
Доброе время суток, подскажите, правильно ли я делаю удаление одинаковых строк? сам код рабочий, но вот незадача... очень долго...

Удаление одинаковых строк в StringGrid1
Как в StringGrid удалить абсолютно одинаковые строчки? Пробовал переделать найденный код для делфи на билдер, но не вышло..

Удаление одинаковых строк Листбокс
Делаю игру алхимия и там добавляются одинаковые строки в лисбокс, а как сделать чтоб они одинаковые недобавлялись? или если добавились то...

3
1090 / 588 / 121
Регистрация: 11.11.2008
Сообщений: 1,544
14.06.2011, 06:43
поясните почему
newnj = 2
newni = 5
?
как это сопоставить с
110000...000
110000...000
110000...000
110000...000
110000...000
101000...000
000000...000
?

не задумывались над тем, чтоб решить задачу проще? например, преобразовать массив в список строк и использовать готовые методы.
1
 Аватар для kzru_hunter
1124 / 795 / 101
Регистрация: 01.02.2011
Сообщений: 1,887
Записей в блоге: 1
14.06.2011, 07:20
Сделал наподобие вашей задачи.
Исходный массив:
2 2
2 1
3 2
2 2
3 2
В результате выводит:
2 2
2 1
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
        const int otvetinj = 2; // кол-во столбцов в исходном массиве
        const int otvetini = 5; // кол-во строк в исходном массиве
 
        int otvetibuff[otvetini][otvetinj] = {0}; // исходный массив
        int newbuff[otvetini][otvetinj] = {0}; // массив, в который будем лобавлять неповторяющиеся строки
 
        // -------- заполнение массива -------
        otvetibuff[0][0] = 2;
        otvetibuff[0][1] = 2;
 
        otvetibuff[1][0] = 2;
        otvetibuff[1][1] = 1;
 
        otvetibuff[2][0] = 3;
        otvetibuff[2][1] = 2;
 
        otvetibuff[3][0] = 2;
        otvetibuff[3][1] = 2;
 
        otvetibuff[4][0] = 3;
        otvetibuff[4][1] = 2;
        // ------------------------------------
 
 
 
        // --- копирую первую строку из исходного массива в новый -----
        memcpy(&newbuff[0], &otvetibuff[0], sizeof(int) * otvetinj);
        int newni = 1;
        int newnj = otvetinj;
        // ------------------------------------------------------------
 
        // получение неповторяющихся строк
        for ( int i = 0; i < otvetini; i++ )
        {
                bool found = false;
 
                for ( int j = 0; j < newni; j++ )
                {
                        // -------- сравниваем каждую строку исходного массива со строкой нового -----
                        if ( memcmp(&otvetibuff[i], &newbuff[j], sizeof(int)*otvetinj) == 0 )
                        {
                                found = true;
                                break;
                        }
                        // ----------------------------------------------------------------------------
                }
 
                // ------- добавляем неповторяющуюся строку в новый массив -------
                if ( !found )
                {
                        memcpy(&newbuff[newni], &otvetibuff[i], sizeof(int)*otvetinj);
                        newni++;
                }
                // ---------------------------------------------------------------
        }
 
        // --------------------- выводим неповторяющиеся строки в Memo -----------
        Memo1->Clear();
        for ( int i = 0; i < newni; i++ )
        {
                AnsiString Text = "";
                for ( int j = 0; j < newnj; j++ )
                {
                        Text += AnsiString(newbuff[i][j]) + " ";
                }
                Memo1->Lines->Add(Text);
        }
        // ------------------------------------------------------------------------
1
Kisellev
14.06.2011, 11:33
Спасибо за идеи и решение, попробую осмыслить)))
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
14.06.2011, 11:33
Помогаю со студенческими работами здесь

Удаление двумерного массива
Доброго времени суток! Подскажите пожалуйста, как правильно удалить двумерный массив, созданный таким образом: Graphics::TBitmap...

Удаление двумерного динамического массива
Здравствуйте. Возникла ошибка при удалении двумерного динамического массива: сам код: TStringList** TMP_CAT = new...

Удаление двумерного массива объектов без утечки памяти
Как удалить созданные объекты без утечки памяти? Screen = new TPanel**; for(int i = 0; i &lt; N; i++) { Screen = new...

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

Удаление строк из двумерного массива
Подскажите, пожалуйста, как исправить код, чтобы удалялись только те строки, что поэлементно меньше. Т.е.т.е. 1 4 5 3 и 1 3 5 2 ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 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 считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru