• 締切済み

ガウスの消去法:C言語

連立方程式をガウスの消去法を用いて解くプログラミングをVisual Studioで作成したいのですが、ビルドがうまくいきません ビルドをすると、 ・リンケージ指定子がグローバル スコープで宣言されていません ・直前のエラーを修復できません。コンパイルを中止します。 と表示されデバックできません。 どなたかご教授願います。 ちなみに、C++ win32コンソールアプリケーションを使用しています。 ソースコード↓ #include "stdafx.h" int _tmain(int argc, _TCHAR* argv[]) { #include <stdio.h> #include <math.h> #define EPS 1.0e-5 #define N 10 void DATAIN(char name[], int nr, int nc, double ma[]); void RESULT(char name[], int nr, int nc, double ma[]); int PIVOT(int *num, int nr, int k, double ma[]); int GAUSS(int nr, double ma[], double mb[], double mx[]); int main(void) { int nr,nc; int flag; double ma[N*N],mb[N],mx[N]; printf("方程式の数 nr="); scanf("%d",&nr); nc=nr; printf("\n配列maのデータ%d*%d=%d",nr,nr,nr*nr); printf("個を入力"); DATAIN("ma",nr,nc,ma); printf("\n配列mbのデータ %d 個を",nr); printf("入力してください"); DATAIN("mb",nr,1,mb); flag=GAUSS(nr,ma,mb,mx); if(flag) printf("計算不能"); else RESULT("mx",nr,1,mx); return (0); } void DATAIN(char name[], int nr, int nc, double ma[]) { int i,j; printf("\n---入力データ---\n"); for(i=0; i<nr; i++) { for(j=0; j<nc; j++) { printf(" %s[%d%d] = ",name,i+1,j+1); scanf("%lf",&ma[nc*i+j]); } } } void RESULT(char name[], int nr, int nc, double ma[]) { int i,j; printf("\n---計算結果---\n"); for(i=0; i<nr; i++) { for(j=0; j<nc; j++) printf(" %s[%d] = %8.5lf",name,i+1,ma[nc*i+j]); printf("\n"); } } int PIVOT(int *num, int nr, int k, double ma[]) { int i; double aa,bb; *num=k; aa=fabs(ma[nr*k+k]); for(i=k+1; i<nr; i++) { if (fabs(ma[nr*i+k])>aa) { *num=i; aa=fabs(ma[nr*i+k]); } } if(fabs(aa)<=EPS) return (1); if(*num==k) return (0); for(i=k; i<nr; i++) { bb=ma[nr*k+i]; ma[nr*k+i]=ma[nr*(*num)+i]; ma[nr*(*num)+i]=bb; } return (0); } int GAUSS(int nr, double ma[], double mb[], double mx[]) { int i,j,k; int num; double cc; for(k=0; k<nr-1; k++) { if(PIVOT(&num,nr,k,ma)!=0) return (1); if(num!=k) { cc=mb[num]; mb[num]=mb[k]; mb[k]=cc; } for(i=k+1; i<nr; i++) { cc=ma[nr*i+k]/ma[nr*k+k]; for(j=k+1; j<nr; j++) ma[nr*i+j]=ma[nr*i+j]-cc*ma[nr*k+j]; mb[i]=mb[i]-cc*mb[k]; } } for(k=nr-1; k>=0; k--) { if(fabs(ma[nr*k+k])<=EPS) return(1); cc=0.0; for(j=k+1; j<nr; j++) cc+=ma[nr*k+j]*mx[j]; mx[k]=(mb[k]-cc)/ma[nr*k+k]; } return (0); } return 0; }

みんなの回答

noname#227064
noname#227064
回答No.1

最初の > #include "stdafx.h" > int _tmain(int argc, _TCHAR* argv[]) > { と、最後の > return (0); > } を削除してビルドしてください。

関連するQ&A

  • C言語で行列の積を計算できるような関数を作って疑問に思ったことがありま

    C言語で行列の積を計算できるような関数を作って疑問に思ったことがあります。 まず↓のような2x3行列と3x2行列が計算できる関数を作りました、、 #include <stdio.h> void mul(const int ma[2][3],const int mb[3][2],int mc[2][2]) { int i,j,k; for(i = 0; i < 2; i++) for(j = 0;j < 2;j++) for(k=0;k<3;k++) mc[i][j]+=ma[i][k]*mb[k][j]; } int main(void) { int i,j; int ma[2][3] ={{1,2,3},{4,5,6}}; int mb[3][2] ={{7,8},{9,0},{1,2}}; int mc[2][2] ={0}; mul(ma,mb,mc); for(i = 0;i < 2; i++) { for(j = 0;j < 2;j++) printf("%4d",mc[i][j]); putchar('\n'); } eturn(0); } ---------------------------------- これをmxn,nxp行列で計算できるような関数にしたいと思い 下のようにしたのですがエラーになります。どうしたらいいでしょうか・・? #include <stdio.h> void mul(const int ma[int m][int n],const int mb[int n][int p],int mc[m][p]) { int i,j,k; for(i=0;i<m;i++) for(j=0;j<p;j++) for(k=0;k<n;k++) mc[i][j]+=ma[i][k]*mb[k][j]; } int main(void) {int i,j; int ma[2][3] ={{1,2,3},{4,5,6}}; int mb[3][2] ={{7,8},{9,0},{1,2}}; int mc[2][2] ={0}; mul(ma,mb,mc); for(i = 0;i < 2; i++) {for(j = 0;j < 2;j++) printf("%4d",mc[i][j]); putchar('\n');} return(0);}

  • ガウスのの単純消去法のプログラムです。

    ガウスのの単純消去法のプログラムです。 前進消去の第k段階が終わった段階でaij,biが表示されるようにしたいんですがどうすればいいでしょうか↓ よろしくお願いします。 #include<stdio.h> #include<stdlib.h> #include<math.h> #define ERROR -1 #define EPS 1.0e-15 int gausssimp(double *, double *, double *, int); int main(void) { double *a,*b,*x,val; char s[32]; int i,j,n,result; printf("Input size n="); gets(s); sscanf(s,"%d",&n); if((a=(double *)calloc(n*n,sizeof(double)) ) == NULL){ fprintf(stderr,"Memory allocation error\n"); exit(-1); } if((b=(double *)calloc(n,sizeof(double))) == NULL){ fprintf(stderr,"Memory allocation error\n"); exit(-1); } if((x=(double *)calloc(n,sizeof(double))) == NULL){ fprintf(stderr,"Memory allocation error\n"); exit(-1); } /* A,b の成分を入力 */ printf("----- A -----\n"); for(i=0; i<n; i++){ for(j=0; j<n; j++){ printf("a(%2d,%2d)=",i+1,j+1); gets(s); sscanf(s,"%lf",&val); a[n*i+j]=val; } } printf("\n----- b -----\n"); for(i=0; i<n; i++){ printf("b(%2d)=",i+1); gets(s); sscanf(s,"%lf",&val); b[i]=val; } /* Gaussの単純消去法による求解 */ result = gausssimp(x,a,b,n); /* 解の表示 */ if(result == ERROR){ printf("ERROR occurs. pivot 0\n"); } else { printf("\n----- solution -----\n"); for(i=0; i<n; i++){ printf("x(%2d)=%.8e\n",i+1, x[i]); } } free(a); free(b); free(x); return 0; } int gausssimp(double *x, double *a, double *b, int n) { int i,j,k; double tmp,p,sum; /* step 1: 前進消去 */ /**** 追加 ****/ /* 前進消去の各段階を終えるごとに,式がどのように変化しているかわかるように表示する */ /**************/ for(k=0; k<n-1;k++){ if(a[n*k+k] == 0.0) { /* ピボットの値が0.割り算でエラーが起きる.*/ return ERROR; } else { /* k+1番目以降の式から x[k] の項を消去 */ for(i=k+1; i<n; i++){ p=a[n*i+k]/a[n*k+k]; for(j=0; j<n; j++){ a[n*i+j]=a[n*i+j]-p*a[n*k+j]; } b[i]=b[i]-p*b[k]; printf("a[%d %d]=%d b[%d]=%d",i,j,a[n*i+j]-p*a[n*k+j],i,b[i]-p*a[n*k+j]); ↑これではできませんでした。。。 } /**********************************/ } printf("k=%d\n",k); } /* step 2: 後退代入 */ for(k=n-1; k>=0; k--){ if(fabs(a[n*k+k]) < EPS) return(ERROR); sum=0.0; for(j=k+1; j<n; j++) sum+=a[n*k+j]*x[j]; x[k]=(b[k] - sum)/a[k*n+k]; } return 0; }

  • C言語★

    012   012 123 × 123 234   234 を計算させるために以下の関数と表示するプログラムを作りました。 しかし、セグメントエラーで実行できません。 関数 void matprod(int nrow,int ncol,double **a,double **b,double ** prod){ int i,j,k; for(i=0;i<nrow;i++){ for(j=0;j<ncol;j++){ for(k=0;k<ncol;k++){ prod[i][j]=a[k][j]*b[i][k];} } } return ; } 表示部分 matprod(3,3,a,b,prod); for(i=0;i<nrow;i++){ for(j=0;j<ncol;j++){ printf("%d",prod[i][j]); //3*3の計算をして、答えを表示する。 }} この中に間違えがあると思うのですが、いくらチェックしても分かりません。>< お願いです。 どなたか、間違いを分かる方がいらっしゃったら教えてください!!

  • c言語 プログラム ピラミッド

    プログラミングについて教えてください プログラムは ピラミッドの図形をユーザーが指定した数字で正三角形の ピラミッドの段数を指定できるプログラムです 例えば「5」と打てば ********* ■ ********■■■ ******■■■■■ ****■■■■■■■ **■■■■■■■■■ このような感じに表示されます *の部分は空白です #include<stdio.h> int main (void) { int num,i,j,h; printf("ピラミッドの高さを入力してください : "); scanf("%d" ,&num); for(i=1; i<=num; i++){ for(j=num; j>=i+1; j--){ printf(" ",j); } for(h=1; h<=j; h++){ printf("■"); } printf("\n"); } return 0; } ここまで出来ています、詰まっているのでご教授ください よろしくお願いします

  • ガウスの消去法のプログラムについて

    ガウスの消去法のプログラムについて #include <stdio.h> #define N 3 void main(void) { static double a[N][N+1]={{3.0, 1.0, 1.0, 8.0}, {6.0, 2.0, 3.0, 4.0}, {9.0, 4.0, 5.0, 12.0}}; double d; int i,j,k; for (k=0;k<N-1;k++){ for (i=k+1;i<N;i++){ d=a[i][k]/a[k][k]; for (j=k+1;j<=N;j++) a[i][j]=a[i][j]-a[k][j]*d; } } for (i=N-1;i>=0;i++){ d=a[i][N]; for (j=i+1;j<N;j++){ d=d-a[i][j]*a[j][N]; a[i][N]=d/a[i][i]; } } for (k=0;k<N;k++){ printf("x%d=%f\n",k+1,a[k][N]); } } というプログラムを実行したら 8-5.c: In function `main': 8-5.c:4: warning: return type of `main' is not `int' と出たのですがどこを直せばよいのでしょうか?><

  • C言語でのプログラム

    全対最短経路(フロイドのアルゴリズム)のプログラムを作成したんですが、以下のようなメッセージが出てしまい、どこが悪いのかさっぱりわかりません。どなたかご教授願えないでしょうか? <プログラム> #include<stdio.h> #define NC 999 /* It should be large enough. */ #define N 5 void floyd(int, int [][], int [][], int [][]); int W[N][N] = { { 0, 1, NC, 1, 5 }, { 9, 0, 3, 2, NC }, { NC, NC, 0, 4, NC }, { NC, NC, 2, 0, 3 }, { 3, NC, NC, NC, 0 }, }; int P[N][N]; int D[N][N]; main() { floyd(N, W, D, P); } void floyd(int n, int W[][], int D[][], int P[][]) { int i, j, k; for(i=0;i<n;i++){ for(j=0;j<n;j++){ P[i][j] = 0; } } for(i=0;i<n;i++){ for(j=0;j<n;j++){ D[i][j] = W[i][j]; } } for(k=0;k<n;k++){ for(i=0;i<n;j++){ for(j=0;j<n;j++){ if(D[i][k]+D[k][j]<D[i][j]){ P[i][j] = k; D[i][j] = D[i][k] + D[k][j]; } } } } printf("?nall pairs of the shortest pathes:?n"); for(i=0;i<n;i++){ for(j=0;j<n;j++){ printf("%3d ", D[i][j]); } printf("?n"); } printf("?n"); } <エラーメッセージ> In function `floyd': :30: error: invalid use of array with unspecified bounds :36: error: invalid use of array with unspecified bounds :43: error: invalid use of array with unspecified bounds :44: error: invalid use of array with unspecified bounds :45: error: invalid use of array with unspecified bounds :54: error: invalid use of array with unspecified bounds

  • C言語

    #include <stdio.h> #include <stdib.h> int main (void){ double a[5]={0.0,4.0,0.0,-5.0,1.0}; double x; int i,j,k,n; n=4; x=0.75; for(i=1;i<=n;i++) printf("%10.5f ,",a[i]); printf("\n"); for (i=1; i<=n+1; i++) printf("----------") printf("\n"); while(n>=1){ for(i=1; i<=n; i++) a[i]=a[i-1]*x+a[i]; for(i=1; i<=n; i++) prontf("%10.5f ,"a[i]); printf("\n"); n=n-1; } return 0; }

  • ガウスの消去法

    逆行列を求めたいのですが どうも上手くできません。 下にソースコードを載せますので どなたかどこが悪いのか ご教授してくれませんか? よろしくお願いします。 void MINV(double A[][100],double InvAf2[][100],int G,int R){ int i,j,k; double temp;//行列値の一時記憶 double B[100][100],C[100][100];//行列の一時記憶 for(k=0;k<R;k++){//k列目を調整する for(i=0;i<G;i++){//行数を指す for(j=0;j<R;j++){//列数を指す temp=A[k][k]; B[i][j]=A[i][j];//InvAf2を計算するのに必要 C[k][j]=InvAf2[k][j];//InvAf2を計算するのに必要(更新した値を使われると困る) if(i==k){ A[i][j]/=temp; InvAf2[i][j]/=temp; } else{ A[i][j] -= A[k][j] * A[i][k] / temp; InvAf2[i][j] -= C[k][j] * B[i][k] / temp; } } } } }

  • ガウス消去

    行列3*3で4列目に答えが入る、ガウス消去の前進消去のプログラムを考えたのですが、3行目まで正規化してしまいます。 前進消去したのを行列mに格納しています。 int main() { int i, j, k,n=3; double a[3][4]={{ 3, 2,-3,-2}, { 2,-2, 1, 7}, {-3, 6, 5,28}}; double m[3][4]; /* 前進消去 */ for( i = 0; i < n; i++ ) { for( j = i+1; j <= n; j++ ) { m[i][j] = a[i][j]/a[i][i]; m[i][i]=1; for( k = i+1; k <= n+1; k++ ) { a[k][j] = a[k][j] -a[k][i] * m[i][j]; m[j][i]=0; }}}

  • 助けてください! c言語のプログラムです。

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <math.h> #define KAMOKU_SUU 5 #define AVE_INDEX KAMOKU_SUU typedef struct { char name[32]; int scor[KAMOKU_SUU]; int mean; } STUDENT; int round(double d) { if (d < 0) return (int)(d-0.5); else return (int)(d+0.5); } #define ARRAY_OF(a) (sizeof (a) / sizeof (a[0])) int main(int argc,char* argv[]) { int i, j,k, n; int nStudets; double avrg[KAMOKU_SUU + 1]; double stdv[KAMOKU_SUU + 1]; STUDENT *mem; char buff[80]; if (argc < 2) { printf("!パラメータ不足\n"); return 1; } nStudets = atoi(argv[1]); mem = (STUDENT*)malloc(sizeof (STUDENT) * nStudets); if (mem == NULL) { printf("!アロケーション\n"); return 2; } memset(avrg, 0, sizeof (avrg)); memset(stdv, 0, sizeof (stdv)); printf("生徒 %d 名分の成績を入力してください:\n", nStudets); for (k = 0; k < nStudets; k++) { printf("%d 人目の点数と名前 > ", k + 1); gets(buff); strcpy(mem[k].name, strtok(buff," ")); mem[k].mean = 0; for (j = 0; j < KAMOKU_SUU; j++) { int i = mem[k].scor[j] = atoi(strtok(NULL," \n")); mem[k].mean += i; avrg[j] += i; stdv[j] += i * i; } mem[k].mean = round(mem[k].mean * 1.0 / KAMOKU_SUU); } for(j = 0; j < KAMOKU_SUU; j++) { avrg[AVE_INDEX] += avrg[j]; stdv[AVE_INDEX] += stdv[j]; avrg[j] = avrg[j] / nStudets; stdv[j] = sqrt(stdv[j] / nStudets - avrg[j] * avrg[j]); } n = nStudets * KAMOKU_SUU; avrg[AVE_INDEX] = avrg[AVE_INDEX]/ n; stdv[AVE_INDEX] = sqrt(stdv[AVE_INDEX] / n) - (avrg[AVE_INDEX] * avrg[AVE_INDEX]); printf("\n成績表\n"); printf("# NAME"); for (i = 1; i <= KAMOKU_SUU; ++i) printf(" #%d ", i); printf("MEAN\n"); for (k = 0; k< nStudets; k++) { printf("%d %10s",k+1,mem[k].name); for (j = 0; j < KAMOKU_SUU; j++) { printf(" %3d",mem[k].scor[j]); } printf(" %3d\n",mem[AVE_INDEX].mean); } printf("------------------------------------\n"); printf(" %10s","average"); for(j = 0; j < ARRAY_OF (avrg);j++) { printf(" %3.0f",avrg[j]); } printf("\n"); printf(" %10s","st.dev."); for ( j = 0; j < ARRAY_OF (stdv); j++) { printf(" %3.0f",stdv[j]); } printf("\n"); printf("正常終了\n"); return 0; }  実行してもできません。原因が全く分かりません。 お願いします。 修正してくださるとありがたいです。