Форум программистов, компьютерный форум CyberForum.ru

Удалить элементы списка, что принадлежат промежутку - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Не могу сделать лабу http://www.cyberforum.ru/cpp-beginners/thread1016894.html
Помогите решить задание Описати функцію, що здійснює циклічний зсув на n позицій праворуч елементів цілочисельного масиву, що містить m елементів (n<m).
C++ Подобие MessageBox выводящего INT и LPCSTR . Не тупо ли ? Привыкшему к удобствам PHP с++ нубу захотелось сделать такое вот извращение.. Функция выводит текст как INT типа так и строкового типа... template< typename mytype > void pre(mytype var) { LPCSTR str; const char * type = typeid(var).name(); if (!strcmp("int", type)) { char buffer; http://www.cyberforum.ru/cpp-beginners/thread1016891.html
C++ Ввод строк на с++
Есть задание. Вводить с клавиатуры строки, пока не будет введено 5 строк, заканчивающихся любыми шестнадцатеричных цифр. Вывести все введенные строки и строки, соответствующие требованиям задания. Отсортировать строки. Вывести длинный строку (строки, если их несколько). Есть код. #include <iostream.h> #include <conio.h> #include <ctype.h> //обработка символов #include <string.h>...
Работа со списками C++
Помогите решить задание. Описати функцію, яка друкує у зворотному порядку значення елементів списку. Тип даних - double
C++ Двухмерный массив, среднее значение столбцов, сортировка по возрастанию этих значений http://www.cyberforum.ru/cpp-beginners/thread1016883.html
Дано матрицу i = 6 j = 6. Найти среднее значение элементов столбцов (Ei / ni) и переставить эти значения столбцов по возрастанию определителей. Есть код начала, но я незнаю как переставить эти средние значения столбцов по возрастанию определителей. #include <iostream.h> #include <math.h> #include <conio.h> void main() { clrscr(); int a; int i,j,sum;
C++/CLI WinForms Как в MessageBox.Show вывести сообщение содержащее спецсимволы? using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace user_root подробнее

Показать сообщение отдельно
caiman
 Аватар для caiman
11 / 11 / 1
Регистрация: 17.11.2013
Сообщений: 39
24.11.2013, 03:44     Удалить элементы списка, что принадлежат промежутку
Написал "список" на Си. Примерно так:
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
#include <stdio.h>
#include <stdlib.h>
 
typedef struct {
    int size;
    int *array;
} List;
 
void arrayPrint(int array[], int size) {
    int last = size - 1;
 
    for ( int i = 0; i < last; i++ ) {
        printf("%d ", array[i]);
    }
    printf("%d\n", array[last]);
}
 
void init(List *list, int size) {
    list->size = size;
    list->array = (int*)malloc(list->size*sizeof(int));
}
 
void append(List *list, int value) {
    list->size += 1;
    list->array = (int*)realloc(list->array ,list->size*sizeof(int));
    list->array[list->size-1] = value;
}
 
void erase(List *list, int position) {
 
    for ( int i = position + 1; i < list->size; i++ ) {
        list->array[i-1] = list->array[i];
    }
    list->size -= 1;
    list->array = (int*)realloc(list->array ,list->size*sizeof(int));
}
 
void kill(List *list) {
    list->size = 0;
    free(list->array);
}
 
 
int main() {
    List list;
    int from, to;
    int array[16] = {1,8,9,0,1,3,2,4,1,12,23,1,23,2,19,1};
 
    scanf("%d %d", &from, &to);
 
    init(&list, 0);
 
    for ( int i = 0; i < 16; i++ ) {
        append(&list, array[i]);
    }
    arrayPrint(list.array, list.size);
    for ( int i = 0; i < list.size; i++ ) {
        if ( list.array[i] >= from && list.array[i] <= to ) {
            erase(&list, i);
            i -= 1;
        }
    }
 
    arrayPrint(list.array, list.size);
    kill(&list);
 
    return 0;
}
Добавлено через 1 минуту
Заполнял при помощи массива, чтобы сделать синтетический тест на основе твоих данных.

Добавлено через 2 минуты
Да, и еще нюанс! Забыл совсем - malloc и realloc могут вернуть указатель "0x0", поэтому добавь проверки в методы append и erase.
 
Текущее время: 17:28. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru