我正在编写一个函数,它只计算DNA的"互补"链,这意味着用G替换C,用A替换T,依此类推。
这是我写的:
#include <stdio.h>
#include <string.h>
#define SIZE 70
int isLegitSequence(char sequence[]);
void getComplementaryStrand(char complementary[],char sequence[]);
int findSubSequence(char sequence[],char subsequence[]);
int findSubComplementary(char sequence[],char subcomplementary[]);
void cutSequence(char sequence[],char tocut[]);
void checkDNAList(char data[][SIZE],int rows,char sequence[]);
void main(){
char dnaSequence[SIZE];
char compDnaSequence[SIZE];
printf("Enter a DNA Strandn");
gets(dnaSequence);
printf("%dn",isLegitSequence(dnaSequence));
getComplementaryStrand(compDnaSequence,dnaSequence);
puts(compDnaSequence);
}
int isLegitSequence(char sequence[]){
int i=0;
while (sequence[i]){
if(sequence[i]=='A'||sequence[i]=='C'||sequence[i]=='G'||sequence[i]=='T');
else return 0;
i++;
}
return 1;
}
void getComplementaryStrand(char complementary[SIZE],char sequence[SIZE]){
int j=strlen(sequence)-1,i;
for(i=0;sequence[i];i++,j--){
if(sequence[i]=='A') sequence[j]='T';
else if(sequence[i]=='C') sequence[j]='G';
else if(sequence[i]=='G') sequence[j]='C';
else sequence[j]='A';
}
complementary[strlen(sequence)]=' ';
}
但是,这是我运行程序时得到的:
Enter a DNA Strand
CGCTC
1
╠╠╠╠╠
Press any key to continue . . .
这是我第一次使用函数,所以我不确定我在这里做错了什么。将不胜感激,但在我的理解范围内,即非常非常基本。
您需要在调用函数的源文件的顶部添加函数getComplementaryStrand
原型。
在源文件的顶部添加以下行:
void getComplementaryStrand(char complementary[SIZE],char sequence[SIZE]);
编辑:与此同时,问题发生了变化...之前是编译错误。OP 请提出一个新问题,而不是用新问题编辑您的原始问题。
仔细查看 getComplementaryStrand()
函数中的 for 循环。是否为正确的字符串赋值?我认为不是。
在getComplementaryStrand()
中,除了结束字符之外,您永远不会在补充字符串中填充任何内容。所以你会得到垃圾。