Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Ксения1717
0 / 0 / 0
Регистрация: 23.10.2016
Сообщений: 6
1

Удаление k-го элемента в индексе

30.10.2016, 20:31. Просмотров 290. Ответов 1
Метки нет (Все метки)

Я полный чайник,скажите почему не работает последняя функция?Понимаю,что вопрос глупый,но я совсем начинающий изучать (Простите.
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
#include "array.h"
#include <stdlib.h>
#include <stdio.h>
#include <iostream>
using namespace std;
 
//реализация методов класса
CDynamicArray::CDynamicArray()
{
    nCount = 0; //начальные значения полей класса: массив пуст
    arr = NULL; //указатель на массив равен нулю
    
 
    
}
 
CDynamicArray::~CDynamicArray()
{
    delete[] arr; //освобождение памяти, занимаемой массивом
}
 
void CDynamicArray::CreateArray(int N)
{
    if (N>0) //если задан корректно новый размер массива – создаём его
    {
        if (arr != NULL) //если массив уже существовал – уничтожаем его
            delete[] arr;
        arr = new int[N];
        nCount = N;
        printf("\nМассив создан\n");
    }
    else
        printf("Ошибка! Размер массива должен быть больше 0\n");
 
}
 
void CDynamicArray::SetValue(int k, int value)
{
    if (k >= 0 && k<nCount) //если элемент существовал, он заменится на текущий
        arr[k] = value;
    else
        printf("Ошибка! Задан неверный индекс массива\n");
}
 
void CDynamicArray::FillArrayRandValues()
{
    if (nCount>0) //условие создания массива, количество его элементов больше 0
    {
        for (int i = 0; i<nCount; i++)
            arr[i] = (rand() % 100)-50;
        DisplayArray();
    }
    else
        printf("Массив не создан\n");
}
 
void CDynamicArray::DisplayArray()
{
    if (nCount>0) //если массив создан 
    {
        for (int i = 0; i<nCount; i++)
            printf("%d ", arr[i]);
        printf("\n");
    }
    else
        printf("Массив не создан\n");
}
 
void CDynamicArray::Delete(int k,int n,int i);
{
    printf("\n k=");
    scanf>>k; //ввод номера элемента, подлежащего удалению
for (i=k; i<n-1; arr[i+1],i++); //удаление k-го элемента
for (i=0; i<n-1; i++) cout<<arr[i]<<"\t"; //вывод измененного массива
n--; //уменьшение количества элементов в массиве
}
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
#define _CRT_SECURE_NO_WARNINGS
#include "array.h"
#include <stdio.h>
#include <conio.h>
#include <locale.h>
#include <stdlib.h>
#include <time.h>
 
int main()
{
    CDynamicArray ar; //создаётся объект класса, при этом автоматически вызывается конструктор
    int key, n, k, val;
    srand(time(NULL)); // включаем генератор случайных чисел
    setlocale(0, "RUS"); // обеспесиваем вывод в консольное окно символов кириллицы
 
    printf("\n\n1 - создание массива\n");
    printf("2 - изменение элементов массива\n");
    printf("3 - заполнение массива случайными числами\n");
    printf("4 - вывод на экран элементов массива\n");
    printf("5 - удаление первого найденного положительного элемента\n");
 
    printf("ESC - выход\n");
    printf("\nВаш выбор: \n");
 
    do
    {
        key = _getch();
        switch (key)
        {
        case '1':
            printf("Введите количество элементов массива: ");
            scanf("%d", &n);
            ar.CreateArray(n);
            break;
        case '2':
            printf("Введите индекс элемента массива: ");
            scanf("%d", &k);
            printf("Введите значение элемента массива: ");
            scanf("%d\n", &val);
            ar.SetValue(k, val);
            break;
        case '3':
            ar.FillArrayRandValues();
            break;
        case '4':
            ar.DisplayArray();
            break;
        case '5':
            ar.Delete(int k,int n,int i);
            printf("Введите удаляемый элемент: ");
            scanf_s("%d", &k);
            break;
        }
    } while (key != 27);
    return 0; //объект класса уничтожается, автоматически вызывается деструктор
}
Ошибки вот такие выдает студия
0
Миниатюры
Удаление k-го элемента в индексе  
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.10.2016, 20:31
Ответы с готовыми решениями:

Вставка элемента в заданную позицию, удаление элемента по заданной позиции, поиск заданного элемента
Добавить в класс &quot;Односвязный список&quot; следующие функции: вставка элемента в заданную позицию,...

Описать класс «множество» (добавление и удаление элемента, пересечение, объединение и удаление множеств )
Описать класс «множество», позволяющий выполнять основные операции – добавление и удаление...

Сделать добавление элемента в массив и удаление элемента из массива используя STL
Всем привет. Помогите пожалуйста написать. Нужно использовать STL. Необходимо сделать добавление...

Реализация списка.Удаление хвостового элемента.Поиск элемента
Всем привет,мое задание выглядит так : В класс List&lt;T&gt; из классной работы добавить следующие...

Удаление элемента из списка и поиск элемента
Нужно удалить определенный элемент из списка. Найти элемент в списк и вывести на него всю...

1
Armatus
55 / 55 / 45
Регистрация: 24.03.2016
Сообщений: 378
Завершенные тесты: 4
30.10.2016, 21:46 2
C++
1
 ar.Delete(int k,int n,int i);
Глупейшая глупость, скорее всего должно было быть:
C++
1
ar.Delete(k,n,i)
Добавлено через 2 минуты
И если вы "полный чайник" , то классы это точно не то что надо изучать сперва.
0
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.10.2016, 21:46

Списки. Инициализация, добавление элемента в начало и после другого элемента. Удаление элемента
uses crt; type list= ^item; item=record data: integer; next:list; end; var l:list;...

Удаление минимального положительного элемента, расположенного после последнего отрицательного элемента
В одномерном массиве размерностью n удалить минимальный среди положительных элементов, выбранный из...

Нахождение максимального элемента кучи, добавление элемента, удаление элемента из кучи
Дано бинарное дерево-куча. Нужно найти максимальный элемент (корень дерева), добавить новый...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.