#include<stdio.h>
#include<stdlib.h>
//#define double long
double absd(double a){
	if (a > 0){
		return a;
	}
	else{
		return -a;
	}
}
int twodemiarr(const double (*a), int m, int n, double (*c)){
    int i, j;
	//return;
	//printf("%p\n", b);
	//int cnt = 0;
	double** b = (double**)malloc(sizeof(double*)*m);
	
	for(i = 0; i < m; i++){
		b[i] = (double*)malloc(sizeof(double*)*n);
	}
	
    for(i = 0; i < m; i++){
    	//return a[i][i];
        for(j = 0; j < n; j++){
            	b[i][j] = a[i*n + j]; 
        }
    }
    //return 1; 
    int rk = -1;
    int h = 0; //initialize pivot of row
	int k = 0; //initialize pivot of column
	while (h < m && k < n-1)
	{
		int i_max = h;
		for(int i = h; i < m; i++){
			if(absd(b[i][k]) > absd(b[i_max][k])){
				i_max = i;
			}
		}
		if (b[i_max][k] == 0){
			k = k + 1;
		}
		else{
			//swap row of h and i_max
			//if (h != i_max)
			//printf("do not change");
			for(int i = 0; i < n; i++){
				double tmp = b[h][i];
				b[h][i] = b[i_max][i];
				b[i_max][i] = tmp; 
			}
			//break;
			double divide = b[h][k];
			b[h][k] = 1;
			for(int i = k + 1; i < n; i++){
				b[h][i] = b[h][i]/divide;
			}

			//elimination
			for(int i = h + 1; i < m; i++){
				double f = b[i][k] ;
				b[i][k] = 0;
				for (int j = k + 1; j < n; j++){
					b[i][j] = b[i][j] - b[h][j] * f;
				}
			}
			//if (h == 2)
			//	break;
			h = h + 1;
			k = k + 1;
		}
		//printf("hh\n");
		//break;
	}
	//return 1;
	h = m - 1;
	k = n - 2;
	while(k >= 0){
		//find the first element of column k which is not 0
		for(h = m - 1; h >= 0; h--){
			if(b[h][k] == 1)
				break;
		}
		if (h == 0){
			;
		}
		else{
			//k column i row
			for(i = h - 1; i >=0 ; i--){
				double f = b[i][k]/b[h][k];
				b[i][k] = 0;
				for(int j = k + 1; j < n; j++){
					b[i][j] = b[i][j] - f * b[h][j];
				}
			}
		}

		k = k - 1;
		//break;
	}
	
	for(i = 0; i < m; i++){
    	//return a[i][i];
        for(j = 0; j < n; j++){
        	c[i*n+j] = b[i][j]; 
        }
    }
    for (i = 0; i < m; i++)
    {
    	free(b[i]);
	}
	free(b);
    return rk;
}




