新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 研友的交流园地,讨论关于计算机考研的方方面面。
    [返回] 计算机科学论坛计算机理论与工程『 计算机考研交流 』 → 请教一个PV问题,大家看看这个算法是否正确 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 2806 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 请教一个PV问题,大家看看这个算法是否正确 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     skidrow013 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:6
      积分:75
      门派:XML.ORG.CN
      注册:2007/4/24

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给skidrow013发送一个短消息 把skidrow013加入好友 查看skidrow013的个人资料 搜索skidrow013在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看skidrow013的博客楼主
    发贴心情 请教一个PV问题,大家看看这个算法是否正确

    大家帮忙看一下这个算法存在什么问题
    先谢了。

    有一个仓库存放两种零件A和B,最大库存容量各为m个,一车间不断取A和B进行装配,每次各取一个。
    为避免零件锈蚀,遵循先入库者先出库的原则。有两组供应商,不断地供应A和B(每次一个),为
    保证齐全和合理库存,当某种零件数量比另一种数量超过n(n<m)时,暂停对数量大的零件的进货,集中
    补充数量小的零件。试用P、V操作正确实现。

    我是用类C语言来描述的。
    fullA,emptyA,
    fullB,emptyB,
    mutexA,mutexB,
    PQA(表示当前允许供应A的数量)
    PQB(表示当前允许供应B的数量)

    初始化
    fullA=0;
    emptyA=m;
    fullB=0;
    emptyB=m;
    mutexA=1;mutexB=1;
    PQA=PQB=n;

    A供货商

    do
    {
       wait(emptyA);

       wait(PQA);

       wait(mutexA);

       for(int i=fullA,fullA!=0&&i>=0,i--)
       
       /*用数组Astore[m]来模拟仓库储存A零件的存储单元集合*/
       Astore[i]=Astore[i+1];

       add an "A" product to Astore[0];
       signal(mutexA);

       signal(fullA);

       signal(PQB);
    }

    B供货商

    do
    {
       wait(emptyB);

       wait(PQB);

       wait(mutexB);

       for(int i=fullA,fullA!=0&&i>=0,i--)
       
       /*用数组Astore[m]来模拟仓库储存A零件的存储单元集合*/
       Astore[i]=Astore[i+1];

       add a "B" product to Astore[0];
       signal(mutexB);

       signal(fullB);

       signal(PQA);
    }

    装配车间

    do
    {
       wait(fullA);

       wait(fullB);

       wait(mutexA);

       wait(mutexB);

       Take an "A" product from Astore[fullA];
        
       Take an "B" product from Bstore[fullB];

       signal(mutexA);
       
       signal(mutexB);

       signal (emptyA);

       signal (emptyB)

    }


       收藏   分享  
    顶(0)
      




    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/30 0:14:00
     
     九九 帅哥哟,离线,有人找我吗?射手座1984-11-25
      
      
      等级:大二期末(Java考了96分!)
      文章:49
      积分:309
      门派:XML.ORG.CN
      注册:2007/5/27

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给九九发送一个短消息 把九九加入好友 查看九九的个人资料 搜索九九在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看九九的博客2
    发贴心情 
    for(int i=fullA,fullA!=0&&i>=0,i--)
       /*用数组Astore[m]来模拟仓库储存A零件的存储单元集合*/
       Astore[i]=Astore[i+1];

    这部分的循环,好像没有多大意义的浪费了操作,
    建议用别的办法,来实现先进先出

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/30 11:04:00
     
     javacap 帅哥哟,离线,有人找我吗?
      
      
      等级:大二(研究汇编)
      文章:23
      积分:241
      门派:XML.ORG.CN
      注册:2007/9/10

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给javacap发送一个短消息 把javacap加入好友 查看javacap的个人资料 搜索javacap在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看javacap的博客3
    发贴心情 
    你这是P,V还是管程阿,怎么全是条件变量
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/30 12:28:00
     
     skidrow013 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:6
      积分:75
      门派:XML.ORG.CN
      注册:2007/4/24

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给skidrow013发送一个短消息 把skidrow013加入好友 查看skidrow013的个人资料 搜索skidrow013在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看skidrow013的博客4
    发贴心情 
    要求是pV所以,我尽力用PV。
    但不知是否会出问题
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/30 17:28:00
     
     skidrow013 美女呀,离线,快来找我吧!
      
      
      等级:大一新生
      文章:6
      积分:75
      门派:XML.ORG.CN
      注册:2007/4/24

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给skidrow013发送一个短消息 把skidrow013加入好友 查看skidrow013的个人资料 搜索skidrow013在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看skidrow013的博客5
    发贴心情 
    以下是引用javacap在2007-11-30 12:28:00的发言:
    你这是P,V还是管程阿,怎么全是条件变量

    要求是用PV操作。
    不知道PV操作有什么具体的要求?

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/11/30 17:29:00
     
     buddha 帅哥哟,离线,有人找我吗?
      
      
      等级:大四(每天看1小时莱昂氏)
      文章:164
      积分:1022
      门派:XML.ORG.CN
      注册:2006/5/7

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给buddha发送一个短消息 把buddha加入好友 查看buddha的个人资料 搜索buddha在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看buddha的博客6
    发贴心情 
    这就是PV吧.
    只不过没有用PASCAL而已
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/12/3 12:58:00
     
     applestar 帅哥哟,离线,有人找我吗?
      
      
      威望:2
      等级:大四(总算啃完XML规范了)
      文章:101
      积分:1228
      门派:XML.ORG.CN
      注册:2007/3/16

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给applestar发送一个短消息 把applestar加入好友 查看applestar的个人资料 搜索applestar在『 计算机考研交流 』 的所有贴子 引用回复这个贴子 回复这个贴子 查看applestar的博客7
    发贴心情 
    信号量只有pv才能访问操作。
    这题很简单的。不需要这么复杂。信号量的设置的是对的。过程不妥
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2007/12/4 19:12:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 计算机考研交流 』 的所有贴子 访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/9/23 10:04:13

    本主题贴数7,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    97.656ms