stackoverflowを使用するのはこれが初めてなので、これを正しく実行していることを願っています。あるクラスの1つのプログラムで問題が発生しましたが、他の2つのプログラムはすでに終了しています。これは問題3です。このPDFに移動し、問題3を下にスクロールすると、このプログラムを完了するために使用している情報が表示されます(ただし、これはひどく書かれています)。とにかく、これらを取得しています。私がコンパイルするときの本当に奇妙なエラー、誰かが私のコードがコンパイルされない/動作しない理由がありますか?プログラムのポイントは、サンプルのDNA入力を読み込み、他の2つと比較することです。説明書に書かれているようにサンプルファイルを作成しました。お時間をいただきありがとうございます!
私が得ているエラー:
dna.c: In function ‘main’:
dna.c:12: error: expected ‘]’ before ‘;’ token
dna.c:13: error: expected ‘]’ before ‘;’ token
dna.c:14: error: expected ‘]’ before ‘;’ token
dna.c:15: error: expected ‘]’ before ‘;’ token
dna.c:21: error: ‘first’ undeclared (first use in this function)
dna.c:21: error: (Each undeclared identifier is reported only once
dna.c:21: error: for each function it appears in.)
dna.c:22: error: ‘second’ undeclared (first use in this function)
dna.c:23: error: ‘third’ undeclared (first use in this function)
dna.c:25: error: ‘last’ undeclared (first use in this function)
dna.c: In function ‘read_DNA’:
dna.c:43: error: expected ‘)’ before ‘;’ token
dna.c:43: error: too few arguments to function ‘fgets’
dna.c:45: error: expected expression before ‘;’ token
dna.c: In function ‘print_DNA’:
dna.c:76: error: expected ‘)’ before ‘;’ token
これが私のコードです
#include <stdio.h>
#define MAX_IN_LENGTH 241;
#define OUT_LENGTH 60;
FILE *input;
FILE *output;
int read_DNA(char sequence[]);
double compare_DNA(char seq1[], char seq2[], char seq3[], int n);
void print_DNA(char seq1[], char seq2[], char seq3[], int n);
int main()
{
char first[MAX_IN_LENGTH];
char second[MAX_IN_LENGTH];
char third[MAX_IN_LENGTH];
int last[MAX_IN_LENGTH];
int i;
int length;
double percent;
input = fopen("dna_input.dat", "r");
output = fopen("dna_output.dat", "w");
length =read_DNA(first);
length =read_DNA(second);
length =read_DNA(third);
fprintf(output,"Comparison between sequence # 1 and sequence #2:\n");
percent=compare_DNA(first, second, last,length);
print_DNA(first, second, last, length);
fprintf(output,"The overlap percentage is %.1f%%\n",percent*100);
fprintf(output,"Comparison between sequence # 1 and sequence #3:\n");
print_DNA(first, third, last,length);
fprintf(output,"The overlap percentage is %.1f%%\n",percent*100);
fprintf(output,"Comparison between sequence # 2 and sequence #3:\n");
percent=compare_DNA(second,third,last,length);
print_DNA(second, third, last, length);
fprintf(output,"The overlap percentage is %.1f%%\n",percent*100);
fclose(input);
fclose(output);
return 0;
}
int read_DNA(char sequence[])
{
fgets(sequence, MAX_IN_LENGTH, input);
int i;
for(i=0; i<MAX_IN_LENGTH; i++)
{
if(sequence[i]=='\0')
return i;
}
return MAX_IN_LENGTH;
}
double compare_DNA(char seq1[], char seq2[], char seq3[], int n)
{
int i,count=0;
for(i=0;i<n-1;i++)
{
if(seq1[i]==seq2[i])
{
seq3[i]=seq1[i];
count++;
}
else
seq3[i]=' ';
}
return (double)count/(n-1);
}
void print_DNA(char seq1[], char seq2[], char seq3[], int n)
{
int i=0;
int lines, j, start, stop;
lines =n/OUT_LENGTH;
if( n%OUT_LENGTH!=0)
lines++;
for(j=0;j<lines;j++)
{
start=j*OUT_LENGTH;
stop=(j+1)*OUT_LENGTH;
if(stop>=n)
stop=n-1;
for(i=start;i<stop;i++)
fprintf(output,"%c",seq1[i]);
fprintf(output,"\n");
for(i=start;i<stop;i++)
{
fprintf(output,"%c",seq3[i]);
if(seq3[i]==' ')
fprintf(output,"");
}
fprintf(output,"\n");
for(i=start;i<stop;i++)
{
fprintf(output,"%c",seq2[i]);}
fprintf(output,"\n");
}
}