Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.59/29: Рейтинг темы: голосов - 29, средняя оценка - 4.59
 Аватар для HaRuKy
5 / 5 / 3
Регистрация: 20.03.2011
Сообщений: 299

Удаление выбранной строки массива

02.12.2011, 20:12. Показов 6201. Ответов 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
#include "conio.h"
#include "iostream.h"
#include "alloc.h"
#include "stdlib.h"
void main()
{ clrscr();
  randomize();
  int **a;
  int n,m,i,j,n_str;
  cout<<"Vvedite razmer massiva"<<"\n"; cin>>n; cin>>m;
  a=(int**)malloc(n*m*sizeof(int));
  for (i=0; i<n; i++)
  { for (j=0; j<m; j++)
  {a[i][j]=random(20)-10;
   cout<<a[i][j]<<"  ";  }
   cout<<"\n";
   }
   cout<<"Vvedite nomer stroki dla delete = ";
   cin>>n_str;
   for(i=0; i<n; i++)
   for(j=0; j<m; j++)
   if (n_str==a[i][j]) n_str=i;
 
   delete(a[n_str]); }
   cout<<a[i][j]<<"  ";
}
 Комментарий модератора 
Используйте теги форматирования кода!


Заранее благодарю
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
02.12.2011, 20:12
Ответы с готовыми решениями:

Удаление строки из двумерного массива
Привет всем). Подскажите пожалуйста как удалить строку из двумерного массива, Я объявил динамический массив. Нахожу нулевую строку, опускаю...

Удаление строки или столбца из двумерного массива
Собственно сабж. Как это сделать? Есть какие то методы? Например удалить из массива строку содержащую хоть одну еденицу.

Сохранение строки в массив и удаление повторяющихся элементов массива
Нужно сделать так, что бы строка занасилась в массив без повтора элементов.(к примеру строка: &quot;Травка зеленеет, солнышко...

3
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
02.12.2011, 22:21
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
void *create(size_t size, size_t sizelem)
{
    void *t = (void*) malloc(size * sizelem);
    if (!t)
        exit -1;
    else
        return (void*)t;
}
 
int deletrow(int **arr, int *n, int m, int k)
{
    char i;
 
    if ( ( k > *n ) | ( k <= 0 ) )
        return NULL;
 
    else
    {
        while ( k++ < *n )
            arr[ k - 2 ] = memcpy(arr[ k - 2 ], arr[ k - 1 ], m * sizeof(int));
 
        free( arr[ *n - 1 ] );
        if ( !arr )
            exit ( -1 );
 
        *n = *n - 1;
 
        return 1;
    }
}
 
int main()
{
    int **arr, n = 5, m = 7;
    int k = 2; //номер удаляемой строки считаем с 1 (защита от юзверя)
    // при к = 0 будет выдано сообщение об ошибке
 
    arr = create(n, sizeof(int*));
    for (int i = 0; i < n; ++i)
        arr[ i ] = create(m , sizeof(int));
 
    for (int i = 0; i < n; ++i)
    {
        for (int j = 0; j < m; ++j)
        {
            arr[ i ][ j ] = i + j;
            printf("%2d ", arr[ i ][ j ]);
        }
        puts("");
    }
 
    puts("");
    if ( deletrow(arr, &n, m, k) == 1 )
        for (int i = 0; i < n; ++i)
        {
            for (int j = 0; j < m; ++j)
                printf("%2d ", arr[ i ][ j ]);
            puts("");
        }
    else
        puts("oops");
 
    for(int i = 0; i < n; ++i)
        free(arr[i]);
    free(arr);
 
    return 0;
}
1
 Аватар для HaRuKy
5 / 5 / 3
Регистрация: 20.03.2011
Сообщений: 299
03.12.2011, 10:18  [ТС]
А можешь расписать цикл с удалением выбранной строки для компилятора Turbo Cu ?,а то мы пока в институте на старых компиляторах работаем ...

Или можешь подсказать как правильно поставить цикл во второй части моего куска исходника:

Цитата Сообщение от HaRuKy Посмотреть сообщение
cout<<"Vvedite nomer stroki dla delete = ";
cin>>n_str;
for(i=0; i<n; i++)
for(j=0; j<m; j++)
if (n_str==a[i][j]) n_str=i;
delete(a[n_str]); }
cout<<a[i][j]<<" ";
}
Заранее благодарю
0
 Аватар для alkagolik
1599 / 622 / 113
Регистрация: 15.07.2011
Сообщений: 3,548
03.12.2011, 10:27
Цитата Сообщение от HaRuKy Посмотреть сообщение
А можешь расписать цикл с удалением выбранной строки для компилятора Turbo Cu ?
сама функция соответствует стандарту с89, так что тут бородой не напугать, а вот если не компиляется, то в основном потоке надо из циклов убрать объявления типов и объявить i, j вместе с остальными.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.12.2011, 10:27
Помогаю со студенческими работами здесь

Удаление выбранной строки
Пожалуйста подскажите, как описать удаление выбранной строки ,нажатием на соответствующую кнопку Вот

Удаление выбранной строки
Доброго всем времени суток! У меня вобшем такая проблема: имеется адо-тейбл с полями: 1)номер (тип числовой) 2)фамилия(текстовый) ...

Удаление выбранной строки из datagridview
Здравствуйте Можно ли удалить строку из datagridview не по id строки. Нужно чтобы в datagridview выводило записи из таблицы без столбца...

Удаление выбранной строки в dataGridView
Приветствую. Помогите исправить ошибку &quot;Отсутствует значение для одного или нескольких требуемых параметров&quot;. private void...

Удаление выбранной строки в StringGrid
procedure TForm2.SpeedButton1Click(Sender: TObject); var position:integer; i:integer; begin position:=sg.Row; ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru