| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 393 人关注过本帖
标题:页面置换算法,找不出错误,求解答!
只看楼主 加入收藏
米小兔
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2012-7-14
结帖率:0
收藏
已结贴  问题点数:10 回复次数:2 
页面置换算法,找不出错误,求解答!
#include<iostream.h>
#include <stdlib.h>
#include <time.h>
#include <stdio.h>
#define  L  20//页面走向长度最大为20
int M; //内存块
struct Pro//定义一个结构体
{    int num,time; };
Input(int m,Pro p[L])//打印页面走向状态
{   cout<<"请输入实际页走向长度L(15<=L<=20):";  
   do     {   cin>>m;        
               if(m>20||m<15)cout<<"实际页长度须在15~20之间;请重新输入L: ";         
else break;   
}while(1);   
int i,j;   
  j=time(NULL);//取时钟时间   
srand(j);//以时钟时间x为种子,初始化随机数发生器
  cout<<"输出随机数:  ";      
for(i=0;i<m;i++)   
{ p[i].num=rand( )%10+1;// 1到10之间的随即数放到数组p中      
  p[i].time=0;  
cout<<p[i].num<<" ";     }     
cout<<endl;   
return m; }
void print(Pro *page1)//打印当前的页面
{   Pro *page=new Pro[M];   
page=page1;   
for(int i=0;i<M;i++)  
   cout<<page[i].num<<" ";   
  cout<<endl; }
int  Search(int e,Pro *page1  )//寻找内存块中与e相同的块号
{   Pro *page=new Pro[M];  
   page=page1;   
for(int i=0;i<M;i++)if(e==page[i].num)return i;//返回i值   
return -1; }
int Max(Pro *page1)//寻找最近最长未使用的页面
{   Pro *page=new Pro[M];   
  page=page1;   
int e=page[0].time,i=0;   
  while(i<M)                //找出离现在时间最长的页面   
{   if(e<page[i].time)  e=page[i].time;      
   i++;     }   
for( i=0;i<M;i++)if(e==page[i].time)return i;//找到离现在时间最长的页面返回其块号  
   return -1; }
int Count(Pro *page1,int i,int t,Pro p[L])//记录当前内存块中页面离下次使用间隔长度
{   Pro *page=new Pro[M];   
  page=page1;   
  int count=0;   
for(int j=i;j<L;j++)   
  {   if(page[t].num==p[j].num )break;//当前页面再次被访问时循环结束      
  else count++;//否则count+1     }  
   return count;//返回count的值 }
int main()
{   int c;   
  int m=0,t=0;
float n=0;  
Pro p[L];   
  m=Input(m,p);//调用input函数,返回m值   
cout<<"请输入可用内存页面数m(3~5): ";   
do  
{  cin>>M;  
if(M>5||M<3)  
cout<<"内存块m须在3~5之间,请重新输入m: ";   
else break;
}while(1);      
  Pro *page=new Pro[M];     
do{
    for(int i=0;i<M;i++)//初始化页面基本情况      
   {   page[i].num=0;        
     page[i].time=m-1-i;         }   
     i=0;               
  cout<<"1:FIFO页面置换"<<endl;      
  cout<<"2:LRU页面置换"<<endl;      
  cout<<"按其它键结束程序;"<<endl;      
   cin>>c;      
   system("cls");      
   if(c==1)//FIFO页面置换      
   {  n=0;  
cout<<"      ******************************************       "<<endl;        
cout<<"              FIFO算法页面置换情况如下:           "<<endl;   
cout<<"      ******************************************      "<<endl;            
while(i<m)           
  {
     if(Search(p[i].num,page)>=0)  //当前页面在内存中   
  {  cout<<p[i].num<<"  "; //输出当前页p[i].num   
  cout<<"不缺页"<<endl;   
   i++;         //i加1     
     }      
  else                       //当前页不在内存中              
   {   if(t==M)
         t=0;                    
       else                  
       {  n++;                      //缺页次数加1                  
   page[t].num=p[i].num;//把当前页面放入内存中     
cout<<p[i].num<<"  ";                     
    print(page);            //打印当前页面
                t++;                    //下一个内存块     
  i++;                //指向下一个页面                  
  }            
    }            
}           
  cout<<"缺页次数:"<<n<<"    缺页率:"<<n/m<<endl;           
     }        
if(c==2)//LRU页面置换  
{   n=0;      
cout<<"   ******************************************      "<<endl;   
cout<<"              LRU算法页面置换情况如下:           "<<endl;   
cout<<"     ******************************************     "<<endl;        
while(i<m)   {            
int a;            
t=Search(p[i].num,page);         
   if(t>=0)//如果已在内存块中   
{ page[t].time=0;//把与它相同的内存块的时间置0   
  for(a=0;a<M;a++)   
  if(a!=t)page[a].time++;//其它的时间加1   
cout<<p[i].num<<"  ";   
cout<<"不缺页"<<endl;    }        
     else                  //如果不在内存块中         
   {   n++;           //缺页次数加1              
   t=Max(page);  //返回最近最久未使用的块号赋值给t               
  page[t].num=p[i].num;         //进行替换              
   page[t].time=0;               //替换后时间置为0   
  cout<<p[i].num<<"  ";   
  print(page);   
  for(a=0;a<M;a++)   
  if(a!=t)
      page[a].time++;         //其它的时间加1           
  }     
i++;   
}      
  cout<<"缺页次数:"<<n<<"    缺页率:"<<n/m<<endl;   
}
}while(c==1||c==2||c==3);            
return 0;
}  

E:\U盘\a\a.cpp(54) : error C2601: 'main' : local function definitions are illegal
E:\U盘\a\a.cpp(131) : fatal error C1075: end of file found before the left brace '{' at 'E:\U盘\a\a.cpp(54)' was matched
执行 cl.exe 时出错.

求解!
搜索更多相关主题的帖子: include 结构体 
2013-04-30 10:58
米小兔
Rank: 1
等 级:新手上路
帖 子:61
专家分:0
注 册:2012-7-14
收藏
得分:0 
括号对数应该没有错,可是哪里错了呢,它提示就是main的有问题。
我就没看出来


纠结
求正解!
2013-04-30 11:05
天使梦魔
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:37
帖 子:564
专家分:2754
注 册:2007-8-29
收藏
得分:10 
自己整理一下大括号,main入口都没包含在for中了
代码极度的乱
2013-05-01 11:16
快速回复:页面置换算法,找不出错误,求解答!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017448 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved