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

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

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 11, средняя оценка - 4.73
Visary_Master
 Аватар для Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 19:19     Алгоритмы замещения страниц(STL, вторая попытка) #1
Помогите пожалуйста найти ошибку в алгоритме, вроде все правильно работает, но иногда при разных входных данных возникает ошибка.
Так вот, решил реализовать алгоритм замещения страниц "Вторая попытка".
Коротко о задаче, имеется память ограниченного размера, в память на вход подаются страницы, алгоритм подобен 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!!!
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.02.2012, 19:19     Алгоритмы замещения страниц(STL, вторая попытка)
Посмотрите здесь:

Реализация механизма замещения страниц в ОП C++
STL алгоритмы сортировки C++
C++ Функторы и алгоритмы stl
C++ Задача на С++. Алгоритмы библиотеки STL.
Помогите разобраться (STL, алгоритмы замещения страниц) C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
DU
1477 / 1053 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
26.02.2012, 20:15     Алгоритмы замещения страниц(STL, вторая попытка) #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;
}
Visary_Master
 Аватар для Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 20:31  [ТС]     Алгоритмы замещения страниц(STL, вторая попытка) #3
Ошибку странную выдает...
Миниатюры
Алгоритмы замещения страниц(STL, вторая попытка)  
DU
1477 / 1053 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
26.02.2012, 21:09     Алгоритмы замещения страниц(STL, вторая попытка) #4
хм. у меня без таких глюков.
код в чистом виде скопипастил или модифицировалось что-то после этого?
Visary_Master
 Аватар для Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 21:28  [ТС]     Алгоритмы замещения страниц(STL, вторая попытка) #5
Цитата Сообщение от DU Посмотреть сообщение
код в чистом виде скопипастил или модифицировалось что-то после этого?
Чисто скопипастил, ну и убрал там немного, чтобы переопределений не было, просто у меня 3 алгоритма, фифо, лру, и вторая попытка. Ошибка всегда на последнем элементе последовательности возникает, прога не знает как завершить успешно работу. Может там нужно обработать какое-то исключение?
DU
1477 / 1053 / 45
Регистрация: 05.12.2011
Сообщений: 2,279
26.02.2012, 21:31     Алгоритмы замещения страниц(STL, вторая попытка) #6
очевидно, что где-то там ошибка. и нет смысла о ней говорить не видя кода. может быть все, что угодно. весь код сюда выкладывайте.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
26.02.2012, 22:49     Алгоритмы замещения страниц(STL, вторая попытка)
Еще ссылки по теме:

Алгоритм замещения страниц LRU с помощью методов библиотеки STL C++
Контейнер map и алгоритмы STL: несовместимость? C++
Найти элемент в контейнере priority_queue, используя STL вские итераторы и алгоритмы C++

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

Или воспользуйтесь поиском по форуму:
Visary_Master
 Аватар для Visary_Master
-154 / 16 / 4
Регистрация: 01.12.2010
Сообщений: 297
26.02.2012, 22:49  [ТС]     Алгоритмы замещения страниц(STL, вторая попытка) #7
Все, разобрался. Просто последовательность страниц у меня была организована как динамический массив, для проверки я создал и инициализировал обычный массив, просто забыл в конце закомментить освобождение памяти.

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

Добавлено через 41 минуту
Ссылка на тему с LRU
Yandex
Объявления
26.02.2012, 22:49     Алгоритмы замещения страниц(STL, вторая попытка)
Ответ Создать тему
Опции темы

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