亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sequence.c

?? 是有關基因比對的經典算法的實現。這對于初學計算生物學的人是非常重要的算法。
?? C
?? 第 1 頁 / 共 3 頁
字號:

/* find the start of the sequence entry */
	for (;;) {
		while (fgets(line,MAXLINE+1,fin) != NULL)
                	if( *line == '{' ) break;

		while( !keyword(line,"name") )
			if (fgets(line,MAXLINE+1,fin) == NULL) return;
			
    	for(i=5;i<=strlen(line);i++)  /* DES */
			if(line[i] != ' ') break;
		strncpy(sname,line+i,MAXNAMES); /* remember entryname */
    		for(i=0;i<=strlen(sname);i++)
			if(sname[i] == ' ') {
				sname[i]=EOS;
				break;
			}
		sname[MAXNAMES]=EOS;
		rtrim(sname);
    	blank_to_(sname);
		
/* look for secondary structure feature table / gap penalty mask */
		while(fgets(line,MAXLINE+1,fin) != NULL) {
			if (keyword(line,"feature")) {
				if (interactive) {
					strcpy(title,"Found secondary structure in alignment file: ");
					strcat(title,sname);
					(*lin2)=prompt_for_yes_no(title,"Use it to set local gap penalties ");
				}
				else (*lin2) = 'y';
				if ((*lin2 != 'n') && (*lin2 != 'N'))  {               	
					struct_penalties = SECST;
					for (i=0;i<length;i++)
						sec_struct_mask[i] = '.';
					do {
						if(keyword(line,"feature"))
							get_rsf_feature(&line[7],length);
						fgets(line,MAXLINE+1,fin);
					} while( !keyword(line,"sequence") );
				}
				else {
					do {
						fgets(line,MAXLINE+1,fin);
					} while( !keyword(line,"sequence") );
				}
				strcpy(ss_name,sname);
			}
			else if (keyword(line,"sequence"))
				break;	

			if (struct_penalties != NONE) break;			
		}
						
	}
						
}

static void get_gde_ss(sint length)
{
	static char title[MAXLINE+1];
	static char line[MAXLINE+1];
	static char lin2[MAXLINE+1];
	static char sname[MAXNAMES+1];
	sint i, len, offset = 0;
        unsigned char c;

	for (;;) {
		line[0] = '\0';
/* search for the next comment line */
		while(*line != '"')
			if (fgets(line,MAXLINE+1,fin) == NULL) return;

/* is it a secondary structure entry? */
		if (strncmp(&line[1],"SS_",3) == 0) {
			for (i=1;i<=MAXNAMES-3;i++) {
				if (line[i+3] == '(' || line[i+3] == '\n')
						break;
				sname[i-1] = line[i+3];
			}
			i--;
			sname[i]=EOS;
			if (sname[i-1] == '(') sscanf(&line[i+3],"%d",&offset);
			else offset = 0;
			for(i--;i > 0;i--) 
				if(isspace(sname[i])) {
					sname[i]=EOS;	
				}
				else break;		
			blank_to_(sname);

			if (interactive) {
				strcpy(title,"Found secondary structure in alignment file: ");
				strcat(title,sname);
				(*lin2)=prompt_for_yes_no(title,"Use it to set local gap penalties ");
			}
			else (*lin2) = 'y';
			if ((*lin2 != 'n') && (*lin2 != 'N'))  {               	
				struct_penalties = SECST;
				for (i=0;i<length;i++)
					sec_struct_mask[i] = '.';
				len = 0;
				while(fgets(line,MAXLINE+1,fin)) {
					if(*line == '%' || *line == '#' || *line == '"') break;
					for(i=offset;i < length;i++) {
						c=line[i];
						if(c == '\n' || c == EOS) 
							break;			/* EOL */
						sec_struct_mask[len++]=c;
					}
					if (len > length) break;
				}
				strcpy(ss_name,sname);
			}
		}
/* or is it a gap penalty mask entry? */
		else if (strncmp(&line[1],"GM_",3) == 0) {
			for (i=1;i<=MAXNAMES-3;i++) {
				if (line[i+3] == '(' || line[i+3] == '\n')
						break;
				sname[i-1] = line[i+3];
			}
			i--;
			sname[i]=EOS;
			if (sname[i-1] == '(') sscanf(&line[i+3],"%d",&offset);
			else offset = 0;
			for(i--;i > 0;i--) 
				if(isspace(sname[i])) {
					sname[i]=EOS;	
				}
				else break;		
			blank_to_(sname);

			if (interactive) {
				strcpy(title,"Found gap penalty mask in alignment file: ");
				strcat(title,sname);
				(*lin2)=prompt_for_yes_no(title,"Use it to set local gap penalties ");
			}
			else (*lin2) = 'y';
			if ((*lin2 != 'n') && (*lin2 != 'N'))  {               	
				struct_penalties = GMASK;
				for (i=0;i<length;i++)
					gap_penalty_mask[i] = '1';
				len = 0;
				while(fgets(line,MAXLINE+1,fin)) {
					if(*line == '%' || *line == '#' || *line == '"') break;
					for(i=offset;i < length;i++) {
						c=line[i];
						if(c == '\n' || c == EOS) 
							break;			/* EOL */
						gap_penalty_mask[len++]=c;
					}
					if (len > length) break;
				}
				strcpy(ss_name,sname);
			}
		}
		if (struct_penalties != NONE) break;			
	}			
			
}

static void get_swiss_feature(char *line, sint len)
{
	char c, s, feature[MAXLINE+1];
	int  i, start_pos, end_pos;
	
	if (sscanf(line,"%s%d%d",feature,&start_pos,&end_pos) != 3) {
		return;
	}

	if (strcmp(feature,"HELIX") == 0) {
		c = 'A';
		s = '$';
	}
	else if (strcmp(feature,"STRAND") == 0) {
		c = 'B';
		s = '%';
	}
	else
		return;
			
	if(start_pos >=len || end_pos>=len) return;

	sec_struct_mask[start_pos-1] = s;
	for (i=start_pos;i<end_pos-1;i++)
		sec_struct_mask[i] = c;
	sec_struct_mask[end_pos-1] = s;
		
}

static void get_rsf_feature(char *line, sint len)
{
	char c, s;
	char str1[MAXLINE+1],str2[MAXLINE+1],feature[MAXLINE+1];
	int  i, tmp,start_pos, end_pos;
	
	if (sscanf(line,"%d%d%d%s%s%s",&start_pos,&end_pos,&tmp,str1,str2,feature) != 6) {
		return;
	}

	if (strcmp(feature,"HELIX") == 0) {
		c = 'A';
		s = '$';
	}
	else if (strcmp(feature,"STRAND") == 0) {
		c = 'B';
		s = '%';
	}
	else
		return;
			
	if(start_pos>=len || end_pos >= len) return;
	sec_struct_mask[start_pos-1] = s;
	for (i=start_pos;i<end_pos-1;i++)
		sec_struct_mask[i] = c;
	sec_struct_mask[end_pos-1] = s;
		
}

static void get_swiss_mask(char *line, sint len)
{
	int  i, value, start_pos, end_pos;
	
	if (sscanf(line,"%d%d%d",&value,&start_pos,&end_pos) != 3) {
		return;
	}

	if (value < 1 || value > 9) return;
	
	if(start_pos>=len || end_pos >= len) return;
	for (i=start_pos-1;i<end_pos;i++)
		gap_penalty_mask[i] = value+'0';
		
}

static char * get_seq(char *sname,sint *len,char *tit)
{
	static char line[MAXLINE+1];
	char *seq = NULL;
	sint i, offset = 0;
        unsigned char c=EOS;
	Boolean got_seq=FALSE;

	switch(seqFormat) {

/************************************/
		case EMBLSWISS:
			while( !linetype(line,"ID") )
				if (fgets(line,MAXLINE+1,fin) == NULL) return NULL;
			
                        for(i=5;i<=strlen(line);i++)  /* DES */
				if(line[i] != ' ') break;
			strncpy(sname,line+i,MAXNAMES); /* remember entryname */
                	for(i=0;i<=strlen(sname);i++)
                        	if(sname[i] == ' ') {
                                	sname[i]=EOS;
                                	break;
                        	}

			sname[MAXNAMES]=EOS;
			rtrim(sname);
                        blank_to_(sname);

						
			while( !linetype(line,"SQ") )
				fgets(line,MAXLINE+1,fin);
				
			*len=0;
			while(fgets(line,MAXLINE+1,fin)) {
				if(got_seq && blankline(line)) break;
 				if( strlen(line) > 2 && line[strlen(line)-2]=='.' && line[strlen(line)-3]=='.' ) 
					continue;
				if(seq==NULL)
					seq=(char *)ckalloc((MAXLINE+2)*sizeof(char));
				else
					seq=(char *)ckrealloc(seq,((*len)+MAXLINE+2)*sizeof(char));
				for(i=0;i<=MAXLINE;i++) {
					c=line[i];
				if(c == '\n' || c == EOS || c == '/')
					break;			/* EOL */
				c=chartab[c];
				if(c) {
					got_seq=TRUE;
					seq[++(*len)]=c;
				}
				}
			if(c == '/') break;
			}
		break;
		
/************************************/
		case PIR:
			while(*line != '>')
				fgets(line,MAXLINE+1,fin);			
                        for(i=4;i<=strlen(line);i++)  /* DES */
				if(line[i] != ' ') break;
			strncpy(sname,line+i,MAXNAMES); /* remember entryname */
			sname[MAXNAMES]=EOS;
			rtrim(sname);
                        blank_to_(sname);

			fgets(line,MAXLINE+1,fin);
			strncpy(tit,line,MAXTITLES);
			tit[MAXTITLES]=EOS;
			i=strlen(tit);
			if(tit[i-1]=='\n') tit[i-1]=EOS;
			
			*len=0;
			while(fgets(line,MAXLINE+1,fin)) {
				if(seq==NULL)
					seq=(char *)ckalloc((MAXLINE+2)*sizeof(char));
				else
					seq=(char *)ckrealloc(seq,((*len)+MAXLINE+2)*sizeof(char));
				for(i=0;i<=MAXLINE;i++) {
					c=line[i];
				if(c == '\n' || c == EOS || c == '*')
					break;			/* EOL */
			
				c=chartab[c];
				if(c) seq[++(*len)]=c;
				}
			if(c == '*') break;
			}
		break;
/***********************************************/
		case PEARSON:
			while(*line != '>')
				fgets(line,MAXLINE+1,fin);
			
                        for(i=1;i<=strlen(line);i++)  /* DES */
				if(line[i] != ' ') break;
			strncpy(sname,line+i,MAXNAMES); /* remember entryname */
                        for(i=1;i<=strlen(sname);i++)  /* DES */
				if(sname[i] == ' ') break;
			sname[i]=EOS;
			rtrim(sname);
                        blank_to_(sname);

			*tit=EOS;
			
			*len=0;
			while(fgets(line,MAXLINE+1,fin)) {
				if(seq==NULL)
					seq=(char *)ckalloc((MAXLINE+2)*sizeof(char));
				else
					seq=(char *)ckrealloc(seq,((*len)+MAXLINE+2)*sizeof(char));
				for(i=0;i<=MAXLINE;i++) {
					c=line[i];
				if(c == '\n' || c == EOS || c == '>')
					break;			/* EOL */
			
				c=chartab[c];
				if(c) seq[++(*len)]=c;
			}
			if(c == '>') break;
			}
		break;
/**********************************************/
		case GDE:
			if (dnaflag) {
				while(*line != '#')
					fgets(line,MAXLINE+1,fin);
			}
			else {
				while(*line != '%')
					fgets(line,MAXLINE+1,fin);
			}
			
			for (i=1;i<=MAXNAMES;i++) {
				if (line[i] == '(' || line[i] == '\n')
                                    break;
				sname[i-1] = line[i];
			}
			i--;
			sname[i]=EOS;
			if (sname[i-1] == '(') sscanf(&line[i],"%d",&offset);
			else offset = 0;
			for(i--;i > 0;i--) 
				if(isspace(sname[i])) {
					sname[i]=EOS;	
				}
				else break;		
                        blank_to_(sname);

			*tit=EOS;
			
			*len=0;
			for (i=0;i<offset;i++) seq[++(*len)] = '-';
			while(fgets(line,MAXLINE+1,fin)) {
			if(*line == '%' || *line == '#' || *line == '"') break;
				if(seq==NULL)
					seq=(char *)ckalloc((MAXLINE+2)*sizeof(char));
				else
					seq=(char *)ckrealloc(seq,((*len)+MAXLINE+2)*sizeof(char));
				for(i=0;i<=MAXLINE;i++) {
					c=line[i];
				if(c == '\n' || c == EOS) 
					break;			/* EOL */
			
				c=chartab[c];
				if(c) seq[++(*len)]=c;
				}
			}
		break;
/***********************************************/
		case RSF:
			while(*line != '{')
				if (fgets(line,MAXLINE+1,fin) == NULL) return NULL;
			
			while( !keyword(line,"name") )
				if (fgets(line,MAXLINE+1,fin) == NULL) return NULL;
			
                        for(i=5;i<=strlen(line);i++)  /* DES */
				if(line[i] != ' ') break;
			strncpy(sname,line+i,MAXNAMES); /* remember entryname */
                	for(i=0;i<=strlen(sname);i++)
                        	if(sname[i] == ' ') {
                                	sname[i]=EOS;
                                	break;
                        	}

			sname[MAXNAMES]=EOS;
			rtrim(sname);
                        blank_to_(sname);

						
			while( !keyword(line,"sequence") )
				if (fgets(line,MAXLINE+1,fin) == NULL) return NULL;
				
			*len=0;
			while(fgets(line,MAXLINE+1,fin)) {
				if(seq==NULL)
					seq=(char *)ckalloc((MAXLINE+2)*sizeof(char));
				else
					seq=(char *)ckrealloc(seq,((*len)+MAXLINE+2)*sizeof(char));
				for(i=0;i<=MAXLINE;i++) {
					c=line[i];
					if(c == EOS || c == '}')
						break;			/* EOL */
					if( c=='.')
						seq[++(*len)]='-';
					c=chartab[c];
					if(c) seq[++(*len)]=c;
				}
				if(c == '}') break;
			}
		break;
/***********************************************/
	}
	
	seq[*len+1]=EOS;

	return seq;
}


sint readseqs(sint first_seq) /*first_seq is the #no. of the first seq. to read */
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
老司机午夜精品| 欧美揉bbbbb揉bbbbb| voyeur盗摄精品| 在线观看欧美日本| 久久一二三国产| 婷婷成人综合网| 岛国精品在线播放| 欧美一区二区三区白人| 亚洲日本一区二区| 国产精品原创巨作av| 欧美美女直播网站| 国产精品九色蝌蚪自拍| 精品中文av资源站在线观看| 一本大道av一区二区在线播放| 精品入口麻豆88视频| 亚洲最大色网站| 国产91富婆露脸刺激对白| 91精品国产入口| 亚洲国产美女搞黄色| av在线综合网| 日本一区二区三区四区| 久久99久久99小草精品免视看| 日本久久电影网| 国产精品区一区二区三区| 精品一区二区影视| 欧美一区二区三级| 欧美96一区二区免费视频| 欧美在线免费播放| 亚洲天堂成人网| 色婷婷国产精品| 亚洲自拍偷拍av| 在线观看一区日韩| 亚洲香蕉伊在人在线观| 91官网在线免费观看| 一区二区三区欧美视频| 91视频xxxx| 一级中文字幕一区二区| 欧美性猛交xxxxxxxx| 午夜一区二区三区视频| 欧美日韩色一区| 美女视频黄免费的久久| 日韩一区二区三区四区五区六区| 免费看欧美女人艹b| 欧美va亚洲va| 国产毛片精品一区| 国产精品美女一区二区三区| 成人黄色软件下载| 中文字幕亚洲精品在线观看| 国产成人精品免费视频网站| 26uuu国产在线精品一区二区| 日本亚洲免费观看| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲视频一区二区在线| 国产成人免费高清| 国产欧美日韩一区二区三区在线观看| 韩日av一区二区| 久久久精品天堂| 国产成人免费视频网站| 久久久无码精品亚洲日韩按摩| 久久99精品久久久久婷婷| 日韩欧美一级在线播放| 麻豆国产精品一区二区三区| 欧美一二三四区在线| 精品亚洲免费视频| 欧美韩国日本综合| 成人看片黄a免费看在线| 国产精品色一区二区三区| a亚洲天堂av| 中文字幕一区在线观看| 欧美午夜精品电影| 免费成人美女在线观看| 久久欧美中文字幕| 99v久久综合狠狠综合久久| 亚洲在线观看免费视频| 欧美日韩中文国产| 蜜桃一区二区三区四区| 久久精品一区二区三区四区| 不卡高清视频专区| 亚洲成人免费看| 久久中文字幕电影| 99re6这里只有精品视频在线观看| 一区二区三区四区国产精品| 欧美一区三区四区| 岛国精品一区二区| 五月开心婷婷久久| 欧美国产日韩亚洲一区| 91久久国产综合久久| 日韩精品1区2区3区| 久久久久久久性| 欧美亚州韩日在线看免费版国语版| 日本v片在线高清不卡在线观看| 久久久蜜桃精品| 欧美亚洲免费在线一区| 国产精品一区二区视频| 亚洲精品成人悠悠色影视| 日韩欧美一二区| 91麻豆免费看片| 精品影视av免费| 亚洲精品高清在线观看| 欧美乱妇一区二区三区不卡视频 | 在线综合视频播放| 国产99久久久国产精品免费看 | 日本欧美肥老太交大片| 欧美激情在线一区二区| 欧美丰满嫩嫩电影| 91丨九色丨蝌蚪富婆spa| 秋霞电影网一区二区| 亚洲欧美激情一区二区| 欧美电视剧在线看免费| 欧美性xxxxxx少妇| 99re热视频精品| 国产成人在线观看| 美女mm1313爽爽久久久蜜臀| 亚洲精品视频一区二区| 久久久精品国产99久久精品芒果| 制服.丝袜.亚洲.另类.中文| 精品国产一区二区三区av性色| 久久九九国产精品| 国产一区二区三区蝌蚪| 日本伊人精品一区二区三区观看方式| 日韩毛片一二三区| 国产精品欧美一级免费| 久久久精品综合| 国产乱码精品一区二区三区五月婷| 久久精品亚洲精品国产欧美kt∨| 日韩欧美国产一区二区三区 | 在线日韩一区二区| 国产成人综合亚洲网站| 狠狠色丁香婷婷综合久久片| 久久精品免费观看| 蜜臀av一级做a爰片久久| 午夜激情综合网| 亚洲成人av一区二区三区| 一区二区三区日韩在线观看| 一区二区在线看| 亚洲欧美一区二区三区国产精品| 日本一区二区电影| 国产精品护士白丝一区av| 亚洲国产精品t66y| 中文字幕在线免费不卡| 久久精品日产第一区二区三区高清版 | 亚洲人成伊人成综合网小说| 精品久久久久久久人人人人传媒| 欧美一级日韩免费不卡| 精品日韩一区二区三区| 精品不卡在线视频| 国产三级三级三级精品8ⅰ区| 国产精品色噜噜| 亚洲国产精品一区二区www | 国产日韩高清在线| 久久久久久免费网| 亚洲欧洲成人精品av97| 亚洲男女一区二区三区| 一区二区三区在线观看视频| 亚洲一区二区影院| 久久精品免费观看| 不卡区在线中文字幕| 欧美性受xxxx黑人xyx| 欧美精品一卡两卡| 欧美日韩免费不卡视频一区二区三区| 欧美一二三四在线| 国产精品不卡在线| 亚洲国产sm捆绑调教视频| 免费观看在线色综合| 国产精品综合二区| 99精品视频在线免费观看| 欧美亚洲动漫制服丝袜| 精品国产免费一区二区三区香蕉| 亚洲国产精品激情在线观看| 一区二区三区四区不卡在线 | thepron国产精品| 欧美三级视频在线播放| 欧美疯狂做受xxxx富婆| 亚洲欧洲精品一区二区精品久久久| 亚洲影院久久精品| 国内精品在线播放| 97久久精品人人做人人爽50路| 欧美日韩高清在线播放| 国产欧美一区二区精品仙草咪 | 欧美精品v国产精品v日韩精品| 欧美精品一区二| 亚洲一区二区三区四区在线观看| 久久99精品久久久久久久久久久久| 成人av在线网站| 日韩一区二区在线观看视频| 亚洲天堂久久久久久久| 国产在线不卡视频| 欧美一区二区免费| 亚洲区小说区图片区qvod| 麻豆91在线播放| 欧美午夜电影一区| 国产精品久久久久久久久免费樱桃 | 91老师国产黑色丝袜在线| 欧美成人艳星乳罩| 香蕉久久夜色精品国产使用方法| 国产成人免费高清| 欧美xxxx老人做受| 日韩高清欧美激情| 色综合天天性综合| 亚洲国产精品ⅴa在线观看|