亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 4449 | 回復(fù): 4
打印 上一主題 下一主題

求一個overlap的perl程序 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2014-01-29 08:39 |只看該作者 |倒序瀏覽
向大俠求助

我有一組數(shù)據(jù):
chr1        1        7       
chr1        2        8       
chr1        60        66
chr1        76        82
chr2        1        7       
chr2        4        10
chr2        5        11
chr2        6        12
chr2        9        15

第一列表示不同的染色體,第二列表示起始坐標,第三列表示終止坐標。
第一行(chr1        1        7)和第二行(chr1        2        8)存在坐標交叉,即2在1-7之間。
現(xiàn)在就想找到那些存在坐標交叉的信息,并取出坐標的最小值和最大值。
對于不存在交叉的行,直接print就好。

測試數(shù)據(jù)的結(jié)果應(yīng)該為:
chr1  1  8
chr1  60  66
chr1  76  82
chr2  1  15

論壇徽章:
32
處女座
日期:2013-11-20 23:41:20雙子座
日期:2014-06-11 17:20:43戌狗
日期:2014-06-16 11:05:00處女座
日期:2014-07-22 17:30:47獅子座
日期:2014-07-28 15:38:17金牛座
日期:2014-08-05 16:34:01亥豬
日期:2014-08-18 13:34:25白羊座
日期:2014-09-02 15:03:55金牛座
日期:2014-11-10 10:23:58處女座
日期:2014-12-02 09:17:52程序設(shè)計版塊每日發(fā)帖之星
日期:2015-06-16 22:20:002015亞冠之塔什干火車頭
日期:2015-06-20 23:28:22
2 [報告]
發(fā)表于 2014-01-29 09:52 |只看該作者
  1. my ( $name, $min, $max );
  2. sub print { print "$name $min $max$/" }
  3. while (<DATA>) {
  4.         /(\S+)\s+(\S+)\s+(\S+)/;
  5.         if ( $name ) {
  6.                 if ( $name eq $1 ) {
  7.                         if ( $2 >= $min && $2 <= $max ) {
  8.                                 $max = $3 if $3 > $max;
  9.                                 next;
  10.                         } else {
  11.                                 &print;
  12.                         }
  13.                 } else {
  14.                         &print;
  15.                 }
  16.         }
  17.         ( $name, $min, $max ) = ( $1, $2, $3 );
  18. }
  19. &print;
復(fù)制代碼

論壇徽章:
145
技術(shù)圖書徽章
日期:2013-10-01 15:32:13戌狗
日期:2013-10-25 13:31:35金牛座
日期:2013-11-04 16:22:07子鼠
日期:2013-11-18 18:48:57白羊座
日期:2013-11-29 10:09:11獅子座
日期:2013-12-12 09:57:42白羊座
日期:2013-12-24 16:24:46辰龍
日期:2014-01-08 15:26:12技術(shù)圖書徽章
日期:2014-01-17 13:24:40巳蛇
日期:2014-02-18 14:32:59未羊
日期:2014-02-20 14:12:13白羊座
日期:2014-02-26 12:06:59
3 [報告]
發(fā)表于 2014-01-29 10:26 |只看該作者
回復(fù) 1# tanger_009

$ perl overlay.pl
chr1        1        8
chr1        60        66
chr1        76        82
chr2        1        15

$ cat overlay.pl

use strict;
use warnings;

sub Output{ print join("\t",@_), "\n"}
sub min{ return $_[0] < $_[1] ? $_[0]: $_[1] }
sub max{return $_[0] > $_[1] ? $_[0]: $_[1] }

my @aLast;
while(<DATA>){
  chomp;
  my @aData = split;
  if(@aLast == 0 ){
    @aLast = @aData;
    next;
  }
  if($aLast[0] ne $aData[0]){
    Output(@aLast);
    @aLast = @aData;
    next;
  }
  if($aLast[2] < $aData[1]){
    Output(@aLast);
    @aLast = @aData;
    next;
  }
  $aLast[1] = min($aLast[1], $aData[1]);
  $aLast[2] = max($aLast[2], $aData[2]);
}
Output(@aLast);

__DATA__
chr1        1        7      
chr1        2        8      
chr1        60        66
chr1        76        82
chr2        1        7      
chr2        4        10
chr2        5        11
chr2        6        12
chr2        9        15

   

論壇徽章:
0
4 [報告]
發(fā)表于 2014-01-29 10:55 |只看該作者
謝謝兩位大仙。兩位的都是對的啊~

論壇徽章:
5
丑牛
日期:2014-01-21 08:26:26卯兔
日期:2014-03-11 06:37:43天秤座
日期:2014-03-25 08:52:52寅虎
日期:2014-04-19 11:39:48午馬
日期:2014-08-06 03:56:58
5 [報告]
發(fā)表于 2014-01-29 12:08 |只看該作者
本帖最后由 pitonas 于 2014-01-29 05:22 編輯

if 第二列是升序: 小 -> 大 排列
  1. #!/usr/bin/perl
  2. my @tmp = split /\s+/, <DATA>;

  3. while (<DATA>) {
  4.     my ( $k, $r1, $r2 ) = split;

  5.     if ( $k ne $tmp[0] or $r1 > $tmp[2] ) {
  6.         print join( "\t", @tmp ), "\n";
  7.         @tmp = ( $k, $r1, $r2 );
  8.     }
  9.     elsif ( $r2 > $tmp[2] ) {
  10.         $tmp[2] = $r2;
  11.     }
  12. }
  13. print join( "\t", @tmp ), "\n";

  14. __DATA__
  15. chr1        1        7      
  16. chr1        2        8      
  17. chr1        60        66
  18. chr1        76        82
  19. chr2        1        7      
  20. chr2        4        10
  21. chr2        5        11
  22. chr2        6        12
  23. chr2        9        15
復(fù)制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP