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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
nurs888
0 / 0 / 0
Регистрация: 21.07.2014
Сообщений: 8
#1

Требуется для каждого положения “окна” определить минимум в нём - C++

29.07.2014, 09:05. Просмотров 325. Ответов 4
Метки нет (Все метки)

помогите пожалуйста решить задачу

Рассмотрим последовательность целых чисел длины N. По ней с шагом 1 двигается “окно” длины K, то есть сначала в “окне” видно первые K чисел, на следующем шаге в “окне” уже будут находиться K чисел, начиная со второго, и так далее до конца последовательности. Требуется для каждого положения “окна” определить минимум в нём.

Формат входных данных

В первой строке входных данных содержатся два числа N и K (1 ≤ N ≤ 150000, 1 ≤ K ≤ 10000, K ≤ N) – длины последовательности и “окна”, соответственно. На следующей строке находятся N чисел – сама последовательность.

Формат выходных данных

Выходые данные должны содержать N − K + 1 строк – минимумы для каждого положения “окна”.
Пример

Входные данные

Выходные данные

7 3
1 3 2 4 5 3 1

1
2
2
3
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
#include <iostream>
using namespace std;
    int a[1000000];
    int n;
    int heap_size=0;
 
void heapify(int i){
    int l=2*i,r=2*i+1;int largest=i;
    if(l<=heap_size &&a[l]>a[largest])largest=l;
    if(r<=heap_size &&a[r]>a[largest])largest=r;
    if(largest!=i){
        swap(a[largest],a[i]);
        heapify(largest);
    }
}
 
void build_heap(){
    for(int i=n/2;i>=1;i--)
        heapify(i);
}
 
void heapsort(){
    build_heap();
    while(heap_size>1){
        swap(a[1],a[heap_size]);
        heap_size--;
        heapify(1);
    }
}
void insert(int x){
    heap_size++;
    a[heap_size]=x;
    int n=heap_size;
    while(n!=1){
        if(a[n]>a[n/2]){
            swap(a[n],a[n/2]);
            n/=2;
        }
        else break;
    }
}
int extract(){
    int answer=a[1];
    swap(a[1],a[heap_size]);
    heap_size--;
    heapify(1);
    return answer;
}
int main(){
    
    int x,y;
    cin>>x>>y;
    x=y;
    int arr[n+11];
    heap_size=y;
    for(int i=1;i<=x;i++){
        cin >> arr[i];}
    for(int i=1;i<=x-y+1;i++){
    for(int j=1;j<=y;j++){
    a[j]=-(arr[j+i-1]);
    }
    build_heap();
    cout<<a[1]<<" ";
    }
    
    
return 0;
}
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.07.2014, 09:05
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Требуется для каждого положения “окна” определить минимум в нём (C++):

Требуется для каждого положения “окна” определить минимум в нём - C++
Здрвствуйте, есть ли в стандартных библотеках функция типа make_heap, но наоборот, чтобы куча была от меньшего к большему, нужно для...

Требуется для каждого числа от a до b включительно определить количество натуральных делителей - C++
Требуется для каждого числа от a до b включительно определить количество натуральных делителей. Требуется на одной строке вывести b−a+1...

Дано положительное целое число. Требуется определить количество цифр в нём - C++
Дано положительное целое число. Требуется определить количество цифр в нём. При выполнении данной лабораторной работы необходимо...

В двумерном массиве определить среднее арифметическое каждого столбца и максимум и минимум каждой строки - C++
Дан двухмерный массив 5x6 . Определить среднее арифметическое каждого столбца, определить максимум и минимум каждой строки.

Массив: Для каждого квадрата размером MxM в этой таблице вычислить сумму стоящих в нём чисел. - C++
Здравствуйте, помогите пожалуйста, как можно сделать цикл по перемещению квадрата в матрице. Понятно, что мы должны вычитать и прибавлять...

Минимум, максимум массива, и изменение элементов в нём - C++
Здравствуйте! Следующее задание: Задан одномерный массив А(N). На место минимального элемента массива записать сумму последних k...

4
zss
Модератор
Эксперт С++
6474 / 6037 / 1981
Регистрация: 18.12.2011
Сообщений: 15,621
Завершенные тесты: 1
29.07.2014, 09:18 #2
Цитата Сообщение от nurs888 Посмотреть сообщение
вот нерабочий код
Простите за нескромный вопрос, а какое отношение имеет этот код к задаче?
Напишите самостоятельно хотя бы чтение данных.
Тогда минимум определяется в пару строк
C++
1
2
3
4
5
6
7
8
for(int i=0;i<N-K;i++)
{
    double mn=a[i];
    for(int j=i+1;j<i+K;j++)
         if(a[j]<mn)
             mn=a[j];
    cout<<i<<'\t'<<mn<<endl;
}
0
nurs888
0 / 0 / 0
Регистрация: 21.07.2014
Сообщений: 8
29.07.2014, 09:19  [ТС] #3
собственно, я запутался, это частичное решение
0
zss
Модератор
Эксперт С++
6474 / 6037 / 1981
Регистрация: 18.12.2011
Сообщений: 15,621
Завершенные тесты: 1
29.07.2014, 09:30 #4
Лучший ответ Сообщение было отмечено автором темы, экспертом или модератором как ответ
Цитата Сообщение от nurs888 Посмотреть сообщение
это частичное решение
Может это и частичное решение, но не Вашей задачи.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int main()
{
   int N,K;
   cin>>N>>K;
   double* a=new double[N];
   for(int i=0;i<N;i++)
     cin>>a[i];
   for(int i=0;i<N-K;i++)
   {
      double mn=a[i];
      for(int j=i+1;j<i+K;j++)
         if(a[j]<mn)
             mn=a[j];
      cout<<i<<'\t'<<mn<<endl;
   }
   system("pause");
   return 0;
}
Все!
1
nurs888
0 / 0 / 0
Регистрация: 21.07.2014
Сообщений: 8
29.07.2014, 09:39  [ТС] #5
C++
1
   for(int i=0;i<N-K+1;i++)
+1 только добавить нужно чтобы выход был одинаковым
0
29.07.2014, 09:39
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.07.2014, 09:39
Привет! Вот еще темы с ответами:

Дано натуральное число.Определить,сколько раз в нём встречается минимальная цифра(например, для числа 102200 ответ равен 3,для числа 40330-2,для числ - C++
Дано натуральное число.Определить,сколько раз в нём встречается минимальная цифра(например, для числа 102200 ответ равен 3,для числа...

Требуется напечатать список класса с указанием для каждого ученика количества его однофамильцев - C++
В символьном массиве хранятся фамилии и инициалы учеников класса. Требуется напечатать список класса с указанием для каждого ученика...

Требуется напечатать список класса с указанием для каждого ученика количества его однофамильцев - C++
В символьном массиве хранятся фамилии и инициалы учеников класса. Требуется напечатать список класса с указанием для каждого ученика...

Массив C++ вывести минимум каждого из десятков - C++
Я заполнил массив сотней случайных чисел и разделил на десятки. Теперь просто не знаю куда вставлять условие проверки на минимум (нужно...


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

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

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