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

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

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

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

29.07.2014, 09:05. Просмотров 294. Ответов 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;
}
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.07.2014, 09:05     Требуется для каждого положения “окна” определить минимум в нём
Посмотрите здесь:

После каждого предложения в скобках добавить, сколько раз встретилось в нём введённое с клавиатуры слово C++
Дано натуральное число.Определить,сколько раз в нём встречается минимальная цифра(например, для числа 102200 ответ равен 3,для числа 40330-2,для числ C++
C++ Массив: Для каждого квадрата размером MxM в этой таблице вычислить сумму стоящих в нём чисел.
Требуется напечатать список класса с указанием для каждого ученика количества его однофамильцев C++
Требуется напечатать список класса с указанием для каждого ученика количества его однофамильцев C++
C++ Для заданной матрицы определить среднее арифметическое значение для каждого столбца
Требуется для каждого положения “окна” определить минимум в нём C++
Дано положительное целое число. Требуется определить количество цифр в нём C++
В двумерном массиве определить среднее арифметическое каждого столбца и максимум и минимум каждой строки C++
Массив C++ вывести минимум каждого из десятков C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
zss
Модератор
Эксперт С++
 Аватар для zss
6110 / 5713 / 1849
Регистрация: 18.12.2011
Сообщений: 14,590
Завершенные тесты: 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;
}
nurs888
0 / 0 / 0
Регистрация: 21.07.2014
Сообщений: 8
29.07.2014, 09:19  [ТС]     Требуется для каждого положения “окна” определить минимум в нём #3
собственно, я запутался, это частичное решение
zss
Модератор
Эксперт С++
 Аватар для zss
6110 / 5713 / 1849
Регистрация: 18.12.2011
Сообщений: 14,590
Завершенные тесты: 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;
}
Все!
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 только добавить нужно чтобы выход был одинаковым
Yandex
Объявления
29.07.2014, 09:39     Требуется для каждого положения “окна” определить минимум в нём
Ответ Создать тему
Опции темы

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