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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.73
Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
#1

Алгоритмы замещения страниц(STL, вторая попытка) - C++

26.02.2012, 19:19. Просмотров 1526. Ответов 6
Метки нет (Все метки)

Помогите пожалуйста найти ошибку в алгоритме, вроде все правильно работает, но иногда при разных входных данных возникает ошибка.
Так вот, решил реализовать алгоритм замещения страниц "Вторая попытка".
Коротко о задаче, имеется память ограниченного размера, в память на вход подаются страницы, алгоритм подобен FIFO, отличие в том, что если страница есть в памяти, то она переводится в конец очереди. У меня сделано так, что находится страница которая есть в памяти, и удаляется по ее позиции, а пришедшая страница добавляется в конец очереди(если они совпадают).

Код:
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
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <deque>
#include <algorithm>
#include <utility>
#include <cstdlib>
 
void show_fifo(const deque<int> &dq)
{
    deque<int>::const_iterator i;
    for (i=dq.begin(); i != dq.end(); ++i)
    {
        cout << *i << " ";
    }
     cout << endl;
}
int main()
{
    int mem_size = 5;
    int access_num;
    access_num = 13;
    int array[] = { 1, 2, 3, 4, 5, 2, 3, 4, 1, 5, 4, 1, 3};
 
    cout << "Vtoraya popbitka: " << endl;
    // Vtoraya popitka
    deque<int> dq;    
    
    for (int i=0; i<mem_size; i++)
    {
        dq.push_back(-1);
    }
    cout << "Memory: " << endl;
    show_fifo(dq);
 
    for (int i = 0; i < access_num; ++i)
    {
        cout << "Step " << (i+1) << ":" << endl;
        for (int j = 0; j < dq.size(); j++)
        {
                if ((find(dq.begin(), dq.end(), array[i]) != dq.end()) && (dq.size() != 0))
                {   
                    cout << "Page: " << array[i] << " has in memory" << endl;
                    int del = dq.at(array[i]);
                    dq.erase(dq.begin()+del);
                    dq.push_front(array[i]);
                    break;
                }
                else
                {
                    dq.push_front(array[i]);
                    dq.pop_back();
                    break;
                }
        }
        show_fifo(dq);
    }
Добавлено через 3 часа 57 минут
upppp!!!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.02.2012, 19:19
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Алгоритмы замещения страниц(STL, вторая попытка) (C++):

Помогите разобраться (STL, алгоритмы замещения страниц) - C++
Здравствуйте, хочу реализовать алгоритм замещения страниц памяти FIFO. Не знаю как организовать проверку на присутствие страницы в...

Алгоритм замещения страниц LRU с помощью методов библиотеки STL - C++
Здравствуйте! Мне нужно реализовать алгоритм замещения страниц LRU с помощью методов библиотеки STL. Подскажите пожалуйста, как это сделать...

Реализация механизма замещения страниц в ОП - C++
Необходимо реализовать модель «реализация механизма замещения страниц в ОП». Существует список из N активных страниц (по желанию можно...

Функторы и алгоритмы stl - C++
Добрый день! Интересует такой вопрос. Я хочу, используя стандартный алгоритм стл for_each() и функтор, определить наибольший элемент в...

STL алгоритмы сортировки - C++
Здрасти. В STL есть алгоритмы sort - упорядочивает последовательность и stable_sort - упорядочивает последовательность, не меняя...

Задача на С++. Алгоритмы библиотеки STL. - C++
Программа должна демонстрировать использование контейнерных классов для хранения встроенных типов данных. В программе выполнить...

6
DU
1483 / 1129 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
26.02.2012, 20:15 #2
не совсем понятно что у вы там хотели

У меня сделано так, что находится страница которая есть в памяти, и удаляется по ее позиции...
Вот это довольно неясная формулировка. Должна была удалятся найденная страница страница, у которой индекс в деке совпадает с знацением найденной страницы. Скорее всего имелось в виду первое. Если так, то ошибка в строках 45 и 46.
Вот маленько порефакторенный и исправленный код

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
#include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <deque>
#include <algorithm>
#include <utility>
#include <cstdlib>
 
using namespace std;
 
void show_fifo(const deque<int>& dq)
{
  deque<int>::const_iterator i;
  for (i=dq.begin(); i != dq.end(); ++i)
  {
    cout << *i << " ";
  }
  cout << endl;
}
 
int main()
{
  const int mem_size = 5;
  const int access_num = 13;
  const int array[] = {1, 2, 3, 4, 5, 2, 3, 4, 1, 5, 4, 1, 3};
 
  cout << "Vtoraya popbitka: " << endl;
  deque<int> dq(mem_size, -1);
 
  cout << "Memory: " << endl;
  show_fifo(dq);
 
  for (int i = 0; i < access_num; ++i)
  {
    cout << "Step " << (i+1) << ":" << endl;
 
    deque<int>::iterator pageIter = find(dq.begin(), dq.end(), array[i]);
    if (pageIter != dq.end())
    {       
      cout << "Page: " << array[i] << " has in memory" << endl;
      dq.erase(pageIter);
    }
    else
    {
      cout << "Page: " << array[i] << " not found" << endl;
      dq.pop_back();
    }
 
    dq.push_front(array[i]);
  }
 
  show_fifo(dq);
 
  return 0;
}
1
Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 20:31  [ТС] #3
Ошибку странную выдает...
0
Миниатюры
Алгоритмы замещения страниц(STL, вторая попытка)  
DU
1483 / 1129 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
26.02.2012, 21:09 #4
хм. у меня без таких глюков.
код в чистом виде скопипастил или модифицировалось что-то после этого?
1
Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 21:28  [ТС] #5
Цитата Сообщение от DU Посмотреть сообщение
код в чистом виде скопипастил или модифицировалось что-то после этого?
Чисто скопипастил, ну и убрал там немного, чтобы переопределений не было, просто у меня 3 алгоритма, фифо, лру, и вторая попытка. Ошибка всегда на последнем элементе последовательности возникает, прога не знает как завершить успешно работу. Может там нужно обработать какое-то исключение?
0
DU
1483 / 1129 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
26.02.2012, 21:31 #6
очевидно, что где-то там ошибка. и нет смысла о ней говорить не видя кода. может быть все, что угодно. весь код сюда выкладывайте.
1
Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 22:49  [ТС] #7
Все, разобрался. Просто последовательность страниц у меня была организована как динамический массив, для проверки я создал и инициализировал обычный массив, просто забыл в конце закомментить освобождение памяти.

Добавлено через 7 минут
А можете помочь с более сложным алгоритмом LRU?
Наработки есть, мне помогали в другой теме.

Добавлено через 41 минуту
Ссылка на тему с LRU
0
26.02.2012, 22:49
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.02.2012, 22:49
Привет! Вот еще темы с ответами:

Стандартная библиотека шаблонов STL Алгоритмы - C++
Здравствуйте помогите пожалуйста сделать сортировку по фамилии // ConsoleApplication59.cpp: определяет точку входа для консольного...

Избавиться от цикла, используя алгоритмы из STL - C++
Сделал вот такую функцию... Она создает из вектора ассоциативный массив, у которого ключ - элемент вектора, а значение - частота повторений...

Контейнер map и алгоритмы STL: несовместимость? - C++
Всем доброго времени суток! Столкнулся с проблемой: алгоритм remove_if не работает с контейнером map. Рассмотрим следующую функцию: ...

Алгоритмы STL Удаление элементов в векторе - C++
Банальный вопрос. vector&lt;int&gt; В нем разные числа могут повторяться. Хочу удалить заданное значение, полностью исключить его из вектора. ...


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

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

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