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

Массивы. Удалить из массива все элементы, превосходящие х, а оставшиеся сдвинуть к началу

21.04.2013, 23:52. Показов 2946. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Введите с клавиатуры число х и удалите из массива все элементы, превосходящие х, а оставшиеся сдвинтек началу массива с сохранением последовательности
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.04.2013, 23:52
Ответы с готовыми решениями:

Удалите из массива наименьший и наибольший элементы, сдвинув все оставшиеся элементы к началу массива
Дан массив. Удалите из массива наименьший и наибольший элементы, сдвинув все оставшиеся элементы к началу массива.

Удалить из последовательности все максимальные и минимальные элементы и сдвинуть все остальные к началу
пусть дана последовательность из n элементов. уменьшите ее, удалив все максимальные и минимальные элементы и сдвинув все остальные к началу...

Удалить из массива минимальный элемент и сдвинуть все оставшиеся на одну позицию влево
Дан массив С(30). Удалить из него минимальный элемент и сдвинуть все оставшиеся на одну позицию влево.

10
25 / 25 / 11
Регистрация: 02.01.2012
Сообщений: 371
21.04.2013, 23:57
Удаление элемента массива сдвигом последующих
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
22.04.2013, 00:10
C++
1
2
3
4
    int a[] = {4,2,7,3,3,7,8,8,3,7,8,2,2,6,8};
    int x;
    std::cin>>x;
    std::copy(std::begin(a), std::remove_if(std::begin(a), std::end(a), std::bind2nd(std::greater<int>(), x)), std::ostream_iterator<int>(std::cout, " "));
0
0 / 0 / 0
Регистрация: 16.04.2013
Сообщений: 18
22.04.2013, 00:43
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
#include <iostream>
using namespace std;
 
int main()
{
    setlocale(0, "");
    const int z=5;
 
    int m[z];
 
    cout << "Заполните массив из " << z << " элементов" << endl;
 
    for(int i=0; i<z; i++)
        cin >> m[i];
 
    cout << "Введите x: ";
    int x;
    cin >> x;
    int c = 0;
    for(int k=0; k<z; k++){
        if(x < m[k]){
            c++;
             for (int i=k; i<z-1; m[i+1],i++);}
    }   
        for (int i=0; i<z-c; i++) 
            cout<<m[i]<<"\t"; 
        
    system("pause");
    return 0;
}
Сделал по твоему условию
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
22.04.2013, 02:30
Хотя, запарил, remove_copy_if же есть
0
0 / 0 / 0
Регистрация: 21.04.2013
Сообщений: 8
22.04.2013, 09:41  [ТС]
прошу прощения, сразу не написал, необходимо чтобы массив считывался из файла
0
0 / 0 / 0
Регистрация: 16.04.2013
Сообщений: 18
22.04.2013, 12: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
#include <iostream>
#include <fstream>
using namespace std;
 
int main()
{
    setlocale(0, "");
    const int z=5; 
    int m[z];
    int i = 0;
    ifstream f("Z:\\file.txt");
    while(!f.eof()){
        f >> m[i];
        i++;}
 
    for(i=0; i<z; i++)
        cout << m[i] << "\t";
 
    cout << endl;
 
    cout << "Введите x: ";
    int x;
    cin >> x;
    int c = 0;
    for(int k=0; k<z; k++){
        if(x < m[k]){
            c++;
             for (int i=k; i<z-1; m[i+1],i++);
        }
    }   
        for (int i=0; i<z-c; i++) 
            cout<<m[i]<<"\t"; 
        
    system("pause");
    return 0;
}
Добавил считывание элементов массива из файла
0
0 / 0 / 0
Регистрация: 21.04.2013
Сообщений: 8
22.04.2013, 14:47  [ТС]
вот, что требовалось сделать:

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
#include "stdafx.h"
#include <iostream>
#include "windows.h"
 
using namespace std;
 
void print_mass(int *mass, int n)
{
    int i;
    for(i=0;i<n;i++)
        printf("%d ", mass[i]);
    printf("\n");
 
}
void sdvig(int *mas, int y, int k)
{
    for (int i=k; i<y-1; i++)
        mas[i]=mas[i+1];
    
}
int sravnenie(int *mas, int y, int x)
{
    
    int c=0;
    int n=y;
    for (int i=0; i<y; i++)
    {
        if (x<mas[c]) 
        {
            sdvig(mas,y,c);
            n--;
        }
        else c++;
    }
    return n;
 
}
int main(int argc, char* argv[])
{ 
    int y=0;// кол-во элементов в массиве
    int *mas;
  int z=0;
  int c=0;
  int s=0;
 
  FILE *f;
    int err=fopen_s(&f,"D:\\прога 1\\програ 2\\1.txt", "r");
    if(err)
    {
        printf("error");
        return 0;
    }
    if (fscanf_s(f, "%d", &y)!=1)
    {
        printf("file not found");
        return 0;
    }
    mas=(int*)malloc(sizeof(int)*y);
 
 
    for (int i=0; i<y; i++)
    {
        if(fscanf_s(f, "%d", &mas[i])!=1)
        {
            printf("error");
            free(mas);
            //printf("mas[%d]=%d\n",i,mas[i]);
            return -1;
        }
    }
    cout << "enter x: ";
     int x;
    cin >> x;
    y=sravnenie(mas, y, x);
    print_mass(mas,y);
      return 0;
    
}
0
0 / 0 / 0
Регистрация: 16.04.2013
Сообщений: 18
22.04.2013, 17:21
А зачем, собственно, помощь требовалась?
0
0 / 0 / 0
Регистрация: 21.04.2013
Сообщений: 8
22.04.2013, 18:37  [ТС]
ну помощь требовалась, чтобы сделать программу, которая отвечала бы всем необходимым критериям. а так пришлось 5 часов ей заниматься
0
Почетный модератор
7393 / 2639 / 281
Регистрация: 29.07.2006
Сообщений: 13,696
24.04.2013, 00:35
Цитата Сообщение от Imels Посмотреть сообщение
вот, что требовалось сделать:
ужасть...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.04.2013, 00:35
Помогаю со студенческими работами здесь

Необходимо удалить первое вхождения числа Х в массив, оставшиеся элементы сдвинуть в начало массива
Нужно срочное решение. Пользователь вводит: - размер массива ; - элементы массива ; - число Х . Необходимо удалить первое...

Одномерный массив. Исключить из массива все запятые и пробелы, сдвинуть оставшиеся элементы
Исключить из символьного массива все запятые и пробелы.сдвинуть оставшиеся элементы на освободившиеся места.Прошу помочь в написании...

Удалите из массива все элементы превосходящие "х", а оставшиеся уплотните
введите с клавиатуры число &quot;х&quot; и удалите из массива все элементы превосходящие &quot;х&quot;,а оставшиеся уплотните(т.е. сдвиньте к началу...

Дан массив B(N). Удалить из него минимальный элемент и сдвинуть все оставшиеся елементы на одну позицию влево.
Дан массив B(N). Удалить из него минимальный элемент и сдвинуть все оставшиеся елементы на одну позицию влево. Помогите пожалуйст...

Сдвинуть элементы исходного массива на 5 значений к началу, заполнив пустые места единицами
Сдвинуть элементы исходного массива на 5 значений к началу, заполнив пустые места единицами. Напишите , пожалуйста , функцию как это...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
Вывод данных через динамический список в справочнике
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru