免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2461 | 回复: 4
打印 上一主题 下一主题

求助:有关递归调用的问题!急用~~ [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-09-21 20:19 |只看该作者 |倒序浏览
数据.zip (236.03 KB, 下载次数: 33) 本人想做的是这样一件事:
文件seeds_list.txt为初始节点,文件Adjacency_List.txt为一个以邻接表形式存储的图。根据seeds_list.txt中的初始节点,利用邻接矩阵实现通路查找,先找到与初始节点相同的点,再从此节点开始随机选取与其相连的下一个节点,再将其视为初始节点重复前一步骤,直到无法再找到下一个相连的节点,将此过程中进过的顶点记录下来。最后得到的是N条(N的大小与seeds_list.txt文件中顶点个数相同)通路。
  1. use warnings;
  2. use strict;

  3. my ($seeds,$j,$k);
  4. my (@path,@protein);

  5. open(my $path_list,"Adjacency_List.txt")or die $!;
  6. while(my $path = <$path_list>){
  7.         chomp($path);
  8.         my @temp = split/\t/,$path;
  9.         my @add = [$temp[0],$temp[1]];
  10.         push @protein,@add;
  11. }
  12. close($path_list);

  13. open(my $seeds_list,"seeds_list.txt")or die $!;
  14. open(OUTPUT,">>path_list.txt")or die $!;

  15. while($seeds = <$seeds_list>){
  16.         chomp($seeds);
  17.         $j = 0;
  18.         &find_next_protein($seeds);
  19.         # for my $i(0 .. $#path){  #该for循环用于输出数组path
  20.                 # print OUTPUT "$path[$i]\t";
  21.         # }
  22.         print OUTPUT "\n";
  23.         # @path = ();
  24. }
  25. close();

  26. sub find_next_protein{
  27.         if($j <= $#protein){
  28.                 if($protein[$j][0] eq $seeds){
  29.                         #push @path,$seeds;
  30.                         print OUTPUT "$seeds\t";
  31.                         my @next_temp = split/ /,$protein[$j][1];
  32.                         my $choic_number = int(rand($#next_temp));
  33.                         $seeds = $next_temp[$choic_number];
  34.                         if($protein[$j][0] ne $seeds){
  35.                                 &find_next_protein($seeds);
  36.                         }
  37.                 }else{
  38.                         # if($j <= $#protein){
  39.                                 $j++;
  40.                                 &find_next_protein($seeds);
  41.                         # }
  42.                 }
  43.         }
  44. }
复制代码
捣腾了很久,还是没搞定,急死了~~~
麻烦各位大侠看看,不吝赐教!

论坛徽章:
0
2 [报告]
发表于 2011-09-22 23:57 |只看该作者
本帖最后由 Perlvim 于 2011-09-22 23:59 编辑

一定要用递归调用才行吗?
用其他办法不可以吗?
你说的是不是一个树状结构的遍历循环的问题?
实际应用中节点,通路什么的代表什么数学模型呢?

论坛徽章:
0
3 [报告]
发表于 2011-09-23 09:49 |只看该作者
本帖最后由 arev326 于 2011-09-23 09:53 编辑

回复 2# Perlvim


     用递归应该要容易实现一些。
   我是想在一个无权无向图中找一些通路,起始点就是已经给出的种子节点,然后根据种子节点来随机查找一条通路。
   种子节点在seeds_list.txt中给出,图由邻接表数据文件Adjacency_List.txt给出。数据中的每个节点代表一个蛋白质,边代表蛋白质间的相互作用,而形成的网络就是蛋白质相互作用网。
  各位大仙,帮小弟看看,到底是什么地方错了,或是有什么其他方法实现该操作~~~

论坛徽章:
46
15-16赛季CBA联赛之四川
日期:2018-03-27 11:59:132015年亚洲杯之沙特阿拉伯
日期:2015-04-11 17:31:45天蝎座
日期:2015-03-25 16:56:49双鱼座
日期:2015-03-25 16:56:30摩羯座
日期:2015-03-25 16:56:09巳蛇
日期:2015-03-25 16:55:30卯兔
日期:2015-03-25 16:54:29子鼠
日期:2015-03-25 16:53:59申猴
日期:2015-03-25 16:53:29寅虎
日期:2015-03-25 16:52:29羊年新春福章
日期:2015-03-25 16:51:212015亚冠之布里斯班狮吼
日期:2015-07-13 10:44:56
4 [报告]
发表于 2011-09-23 10:22 |只看该作者
这种应用还是换FP来写吧,Perl 格式化数据还可以

论坛徽章:
0
5 [报告]
发表于 2011-09-23 11:02 |只看该作者
回复 4# zhlong8


    哎~~本人菜鸟一个,只会一点基本的perl~~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP