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

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

?? c_matrix.h

?? 共上載5個源碼
?? H
?? 第 1 頁 / 共 2 頁
字號:
  	row_shift=r_ch(MAT); 
  	col_shift=c_ch(MAT); 
  	for( i=0;i<row;i++){
  		sum=0;
  		for( j=0;j<col;j++){
  			if (row_shift.p[i][j]==0){
  				sum=sum+1;
  			}
  		}
  		if (sum==col){
  			rank1=i;
  			tag1=1;
  			break;
  		}
  	}
  	for( j=0;j<col;j++){
  		sum=0;
  		for( i=0;i<row;i++){
  			if (col_shift.p[i][j]==0){
  				sum=sum+1;
  			}
  		}
  		if (sum==row){
  			rank2=j;
  			tag2=2;
  			break;
  		}
 	 }
 	 if(tag1) {rank=rank1<col?rank1:col;}
 	 if(tag2) {rank=rank2<row?rank2:row;}
	 if(tag1&&tag2){rank=rank1>rank2?rank2:rank1;}
	 free_matrix(&row_shift);
	 free_matrix(&col_shift);
	 return(rank);
	}
	else{
		printf("the arrays is wrong");
		return rank;
	}
}
struct matrix inv(struct  matrix *MAT1){
	int i,j,row=size(MAT1,1),col=size(MAT1,2);
	int ranks=rank(MAT1);
	struct  matrix temp,temps;
	if(row==col){
		if(ranks==row){
			temp=eye(row,col);
			temps=col_rep(MAT1,&temp);
			temps=r_ch(&temps);
			for( i=0;i<row;i++){
				for( j=0;j<col;j++){
					temp.p[i][j]=temps.p[i][col+j];
				}
			}
			return temp;
		}
		else{
			printf("the matrix cannot inv\n");
			temp.row=0;
			temp.col=0;
			return temp;
		}
	}
	else{
		printf("the arow and col are not equae\n");
		temp.row=0;
		temp.col=0;
		return temp;
	}
}
struct matrix find(struct  matrix *MAT1,CLASS NUM,int NUM1){
	int row=size(MAT1,1),col=size(MAT1,2);
	struct  matrix result;
	int i,j,index=-1;
	if (row<1||col<1){
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	else if(NUM1==1){
		result.row=row;result.col=1;
		initial(&result);
		for(i=0;i<row;i++){
			result.p[i][0]=-1;
			for(j=0;j<col;j++){
				if(NUM==MAT1->p[i][j]){
					result.p[i][0]=j;
					break;
				}
			}
		}
	}
	else if(NUM1==2){
		result.row=1;result.col=col;
		initial(&result);
		for(j=0;j<col;j++){
			result.p[0][j]=-1;
			for(i=0;i<row;i++){
				if(NUM==MAT1->p[i][j]){
					result.p[0][j]=i;
					break;
				}
			}
		}
	}
	else{
		printf("the parameter shoude be 1 or 2\n");
	}
	return(result);
}	
struct matrix MAX(struct  matrix *MAT1,CLASS NUM){
	int row=size(MAT1,1),col=size(MAT1,2);
	int i,j,id;
	CLASS temp;
	struct matrix result;
	if (row<1||col<1){
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	else if (NUM==1){
		result.row=row;result.col=2;
		initial(&result);
		for(i=0;i<row;i++){
			temp=MAT1->p[i][0];
			id=0;
			for(j=0;j<col;j++){
				if(MAT1->p[i][j]>temp){
					temp=MAT1->p[i][j];
					id=j;
				}
				else{
					continue;
				}
			}
			result.p[i][0]=temp;result.p[i][1]=id;
		}
	}
	else if(NUM==2){
		result.row=2;result.col=col;
		initial(&result);
		for(j=0;j<col;j++){
			temp=MAT1->p[0][j];
			id=0;
			for(i=0;i<row;i++){
				if(MAT1->p[i][j]>temp){
					temp=MAT1->p[i][j];
					id=i;
				}
				else{
					continue;
				}
			}
			result.p[0][j]=temp;result.p[1][j]=id;
		}
	}
	else{
		printf("the parameter should be 1 or 2			\n");
		result.row=0;
		result.col=0;
	}
	return(result);
					
}
struct matrix MIN(struct  matrix *MAT1,CLASS NUM){
	int row=size(MAT1,1),col=size(MAT1,2);
	int i,j,id;
	CLASS temp;
	struct matrix result;
	if (row<1||col<1){
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	else if (NUM==1){
		result.row=row;result.col=2;
		initial(&result);
		for(i=0;i<row;i++){
			temp=MAT1->p[i][0];
			id=0;
			for(j=0;j<col;j++){
				if(MAT1->p[i][j]<temp){
					temp=MAT1->p[i][j];
					id=j;
				}
				else{
					continue;
				}
			}
			result.p[i][0]=temp;result.p[i][1]=id;
		}
	}
	else if(NUM==2){
		result.row=2;result.col=col;
		initial(&result);
		for(j=0;j<col;j++){
			temp=MAT1->p[0][j];
			id=0;
			for(i=0;i<row;i++){
				if(MAT1->p[i][j]<temp){
					temp=MAT1->p[i][j];
					id=i;
				}
				else{
					continue;
				}
			}
			result.p[0][j]=temp;result.p[1][j]=id;
		}
	}
	else{
		printf("the parameter should be 1 or 2			\n");
		result.row=0;
		result.col=0;
	}
	return(result);
					
}		
struct matrix reshape (struct  matrix *MAT1,int NUM1,int NUM2){
	int row=size(MAT1,1),col=size(MAT1,2);
	int i,j,itemp,jtemp;
	struct  matrix result;
	if((row*col)==(NUM1*NUM2)&&row>0&&col>0){
		result.row=NUM1;
		result.col=NUM2;
		initial(&result);
		for(i=0;i<NUM1;i++){
			for(j=0;j<NUM2;j++){
				itemp=(i*NUM2+j)/col;
				jtemp=(i*NUM2+j)%col;
				result.p[i][j]=MAT1->p[itemp][jtemp];
			}
		}
	}
	else if(!(row>0)&&(col>0)){
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	else{
		printf("the parameter is wrong,cann't reshape\n");
	}
	return(result);
}
struct matrix sort_r (struct  matrix *MAT1,int NUM1){
	int row=size(MAT1,1),col=size(MAT1,2);
	int i,j,k;
	double temp;
	struct  matrix result;
	if(row>1&&col>1){
		if (NUM1==1){
			result=copy(MAT1);
			for(i=0;i<row;i++){
				for(j=0;j<col-1;j++){
					for(k=j+1;k<col;k++){
						if(result.p[i][j]>result.p[i][k]){
							temp=result.p[i][k];
							result.p[i][k]=result.p[i][j];
							result.p[i][j]=temp;
						}
					}
				}
			}
		}
		else if(NUM1==2){
			result=copy(MAT1);
			for(j=0;j<col;j++){
				for(i=0;i<row-1;i++){
					for(k=i+1;k<row;k++){
						if(result.p[i][j]>result.p[k][j]){
							temp=result.p[k][j];
							result.p[k][j]=result.p[i][j];
							result.p[i][j]=temp;
						}
					}
				}
			}
		}
		else{
			printf("the parameter shoude be 1 or 2\n");
			result.row=0;
			result.col=0;
		}
	}
	else if(row==1&&col>1){
		result.row=2;
		result.col=col;
		initial(&result);
		for(j=0;j<col;j++){
			result.p[0][j]=MAT1->p[0][j];
			result.p[1][j]=j;
		}
		if (NUM1==1){
			for(j=0;j<col-1;j++){
				for(k=j+1;k<col;k++){
					if(result.p[0][j]>result.p[0][k]){
						temp=result.p[0][k];
						result.p[0][k]=result.p[0][j];
						result.p[0][j]=temp;
						temp=result.p[1][k];
						result.p[1][k]=result.p[1][j];
						result.p[1][j]=temp;
					}
				}
			}
		}
		if (!(NUM1==2||NUM1==1)){
			printf("the parameter shoude be 1 or 2\n");
			result.row=0;
			result.col=0;
		}
	}
	else if(row>1&&col==1){
		result.row=row;
		result.col=2;
		initial(&result);
		for(i=0;i<row;i++){
			result.p[i][0]=MAT1->p[i][0];
			result.p[i][1]=i;
		}
		if (NUM1==2){
			for(i=0;i<row-1;i++){
				for(k=i+1;k<row;k++){
					if(result.p[i][0]>result.p[k][0]){
						temp=result.p[k][0];
						result.p[k][0]=result.p[i][0];
						result.p[i][0]=temp;
						temp=result.p[k][1];
						result.p[k][1]=result.p[i][1];
						result.p[i][1]=temp;
					}
				}
			}
		}
		if (!(NUM1==2||NUM1==1)){
			printf("the parameter shoude be 1 or 2\n");
			result.row=0;
			result.col=0;
		}
	}
		
		
	else{
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	return(result);
}	
struct matrix sort_d (struct  matrix *MAT1,int NUM1){
	int row=size(MAT1,1),col=size(MAT1,2);
	int i,j,k;
	double temp;
	struct  matrix result;
	if(row>1&&col>1){
		if (NUM1==1){
			result=copy(MAT1);
			for(i=0;i<row;i++){
				for(j=0;j<col-1;j++){
					for(k=j+1;k<col;k++){
						if(result.p[i][j]<result.p[i][k]){
							temp=result.p[i][k];
							result.p[i][k]=result.p[i][j];
							result.p[i][j]=temp;
						}
					}
				}
			}
		}
		else if(NUM1==2){
			result=copy(MAT1);
			for(j=0;j<col;j++){
				for(i=0;i<row-1;i++){
					for(k=i+1;k<row;k++){
						if(result.p[i][j]<result.p[k][j]){
							temp=result.p[k][j];
							result.p[k][j]=result.p[i][j];
							result.p[i][j]=temp;
						}
					}
				}
			}
		}
		else{
			printf("the parameter shoude be 1 or 2\n");
			result.row=0;
			result.col=0;
		}
	}
	else if(row==1&&col>1){
		result.row=2;
		result.col=col;
		initial(&result);
		for(j=0;j<col;j++){
			result.p[0][j]=MAT1->p[0][j];
			result.p[1][j]=j;
		}
		if (NUM1==1){
			for(j=0;j<col-1;j++){
				for(k=j+1;k<col;k++){
					if(result.p[0][j]<result.p[0][k]){
						temp=result.p[0][k];
						result.p[0][k]=result.p[0][j];
						result.p[0][j]=temp;
						temp=result.p[1][k];
						result.p[1][k]=result.p[1][j];
						result.p[1][j]=temp;
					}
				}
			}
		}
		if (!(NUM1==2||NUM1==1)){
			printf("the parameter shoude be 1 or 2\n");
			result.row=0;
			result.col=0;
		}
	}
	else if(row>1&&col==1){
		result.row=row;
		result.col=2;
		initial(&result);
		for(i=0;i<row;i++){
			result.p[i][0]=MAT1->p[i][0];
			result.p[i][1]=i;
		}
		if (NUM1==2){
			for(i=0;i<row-1;i++){
				for(k=i+1;k<row;k++){
					if(result.p[i][0]<result.p[k][0]){
						temp=result.p[k][0];
						result.p[k][0]=result.p[i][0];
						result.p[i][0]=temp;
						temp=result.p[k][1];
						result.p[k][1]=result.p[i][1];
						result.p[i][1]=temp;
					}
				}
			}
		}
		if (!(NUM1==2||NUM1==1)){
			printf("the parameter shoude be 1 or 2\n");
			result.row=0;
			result.col=0;
		}
	}
	else{
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	return(result);
}
struct matrix reset (struct  matrix *MAT1,struct  matrix *index){	
	int row2=size(index,1); int col2=size(index,2);
	int row1=size(MAT1,1);int col1=size(MAT1,2);
	int i,j,itemp,jtemp,id;
	struct  matrix result;
	if(!(row1>0&&row2>0&&col1>0&&col2>0)){
        printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	else if(row1*col1==row2*col2){
		result.row=row1;
		result.col=col1;
		initial(&result);
		for(i=0;i<row1;i++){
			for(j=0;j<col1;j++){
				itemp=(i*col1+j)/col2;
				jtemp=(i*col1+j)%col2;
				id=(int)(index->p[itemp][jtemp]);
				itemp=id/col1;
				jtemp=id%col1;
				result.p[i][j]=MAT1->p[itemp][jtemp];
			}
		}
	}
	else {
		printf("the weishu is not equal\n");
		result.row=0;
		result.col=0;
	}
	
	return(result);
}
struct matrix eig (struct  matrix *MAT1){	
	int row1=size(MAT1,1);int col1=size(MAT1,2);
	int i;
	struct  matrix result;
	if(!(row1>0)&&(col1>0)){
		printf("the matrix is empty\n");
		result.row=0;
		result.col=0;
	}
	else if(row1==col1){
		result.row=row1;
		result.col=1;
		initial(&result);
		for(i=0;i<col1;i++){
			result.p[i][0]=MAT1->p[i][i];
		}
	}
	else{
		printf("the matrix is not square\n");
		result.row=0;
		result.col;0;
	}
	return(result);
}
					
struct matrix ay2mat (CLASS *p, int m,int n){	
	struct matrix result;
	int i,j;
	if(m>0&&n>0){
       result.row=m;
	   result.col=n;
	   initial(&result);
	   for(i=0;i<m;i++){
          for(j=0;j<n;j++){
             result.p[i][j]=*p;
             p++;
          }
       }
    }
    else{
         printf("the matrix is no mean\n");
         result.row=0;
	     result.col=0;
    }
    return(result);
}
void mat2ay (CLASS *p, struct  matrix *MAT1){	
    int m=MAT1->row;
    int n=MAT1->col;
	int i,j;
	if(m>0&&n>0){
	   for(i=0;i<m;i++){
          for(j=0;j<n;j++){
             *p=MAT1->p[i][j];
              p++;
          }
       }
    }
    else{
         printf("the matrix is no mean\n");
         MAT1->row=0;
	     MAT1->col=0;
    }
}
int save(struct  matrix *MAT1,char *p){
    int tag=1;
	const int num=20;
	FILE  *fp;
	char filename[20];
	int i,j;
	for(i=0;i<num;i++){
		filename[i]=*p;
		p++;
	}
	if((fp=fopen(filename,"wb"))==NULL){
		printf("the file cannot open\n");
		tag=-1;
		return(tag);
	}
	
	if(fwrite(&(MAT1->row),4,1,fp)!=1){
        tag=-1;                               
		printf("row read error!\n");
		return(tag);
	}
	if(fwrite(&(MAT1->col),4,1,fp)!=1){
		printf("col read error!\n");
		return(tag);
	}
	
	for(i=0;i<MAT1->row;i++){
		for(j=0;j<MAT1->col;j++){
			if(fwrite(&(MAT1->p[i][j]),8,1,fp)!=1){
				tag=-1;
                printf("element read error!\n");
                return(tag);
			}
			
		}
	}
	fclose(fp);
    return(tag);          
}
int load(struct  matrix *MAT1,char *p){
    int tag=1;
	const int num=20;
	FILE  *fp;
	char filename[20];
	int i,j;
	for(i=0;i<num;i++){
		filename[i]=*p;
		p++;
	}
	if((fp=fopen(filename,"rb"))==NULL){
		printf("the file cannot open\n");
		tag=-1;
		return(tag);
	}
	
	if(fread(&(MAT1->row),4,1,fp)!=1){
        tag=-1;                              
		printf("row read error!\n");
		return(tag);
	}
	if(fread(&(MAT1->col),4,1,fp)!=1){
		tag=-1;
        printf("col read error!\n");
        return(tag);
	}
	initial(MAT1);
	for(i=0;i<MAT1->row;i++){
		for(j=0;j<MAT1->col;j++){
			if(fread(&(MAT1->p[i][j]),8,1,fp)!=1){
				tag=-1;
                printf("element read error!\n");
                return(tag);
			}
			
		}
	}
	fclose(fp);  
    return(tag);            
}
int save_dec(struct  matrix *MAT1,char *p){
    int tag=1;
	const int num=20;
	FILE  *fp;
	char filename[20];
	int i,j;
	for(i=0;i<num;i++){
		filename[i]=*p;
		p++;
	}
	if((fp=fopen(filename,"w"))==NULL){
		printf("the file cannot open\n");
		tag=-1;
		return(tag);
	}
	
    for(i=0;i<MAT1->row;i++){
        fprintf(fp,"\n");                     
		for(j=0;j<MAT1->col;j++){
			fprintf(fp,"%lf ",MAT1->p[i][j]);
			
			
		}
	}
	
	fclose(fp);
    return(tag);          
}


#endif 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品1区2区在线观看| 国产午夜精品久久久久久免费视| 免费成人在线播放| 国产精品成人在线观看| 久久综合一区二区| 日韩一区二区三区三四区视频在线观看| 99视频热这里只有精品免费| 蜜臀av性久久久久av蜜臀妖精 | www久久久久| 欧美大白屁股肥臀xxxxxx| 精品视频123区在线观看| 欧美在线视频你懂得| 91丝袜美女网| 欧美日韩一区二区欧美激情 | 欧美精品久久一区二区三区| 欧美片网站yy| 日韩手机在线导航| 日韩欧美一区在线| 成人三级在线视频| 奇米一区二区三区av| 国产精品久久久久毛片软件| 在线观看91精品国产入口| 99视频一区二区三区| 91精品国产欧美一区二区18| 国产一区二区电影| 在线成人av网站| 一卡二卡欧美日韩| 99精品国产99久久久久久白柏| 久久只精品国产| 精品一区二区三区视频| 日韩视频免费直播| 日本成人在线电影网| 欧美日韩精品系列| 一区二区三区免费看视频| 97久久精品人人爽人人爽蜜臀| 欧美激情在线一区二区| 国产成人av在线影院| 国产喂奶挤奶一区二区三区| 国产黑丝在线一区二区三区| 国产欧美日韩另类一区| 国产成人精品三级| 中文字幕精品一区| 99综合影院在线| 亚洲欧美日韩在线播放| 欧洲精品视频在线观看| 亚洲高清视频中文字幕| 91麻豆精品国产自产在线| 久久99精品久久久久久| 久久综合九色综合久久久精品综合 | 亚洲乱码国产乱码精品精98午夜 | 在线播放一区二区三区| 午夜精品一区二区三区电影天堂 | 国产成人精品亚洲777人妖| 国产精品福利在线播放| 91久久久免费一区二区| 亚洲国产中文字幕在线视频综合| 88在线观看91蜜桃国自产| 久久精品国产久精国产爱| 久久久九九九九| 91免费看`日韩一区二区| 亚洲妇女屁股眼交7| 精品久久久久久久久久久久久久久久久 | 精品视频1区2区| 青青草成人在线观看| 国产亚洲欧美一区在线观看| 91免费观看在线| 美女国产一区二区三区| 国产精品久久久久久久久晋中 | 日韩一区二区电影网| 国产激情一区二区三区四区| 亚洲精品ww久久久久久p站| 欧美一区二区三区免费大片| 成人h动漫精品一区二区| 亚洲国产一区二区在线播放| 国产亚洲精品aa午夜观看| 欧美偷拍一区二区| 国产一区二区免费看| 一区二区三区在线视频观看| 精品999在线播放| 色欧美片视频在线观看在线视频| 麻豆成人久久精品二区三区红 | 伊人开心综合网| 精品国产精品网麻豆系列| 91美女在线视频| 国产福利一区二区三区视频| 天堂资源在线中文精品| 国产精品久久久一区麻豆最新章节| 欧美人伦禁忌dvd放荡欲情| 成人国产精品免费网站| 美女视频一区在线观看| 亚洲国产视频在线| 亚洲丝袜自拍清纯另类| 欧美v亚洲v综合ⅴ国产v| 欧美日韩在线电影| 91女厕偷拍女厕偷拍高清| 国产盗摄一区二区三区| 美腿丝袜亚洲三区| 亚洲网友自拍偷拍| 亚洲激情在线播放| 综合久久给合久久狠狠狠97色| 久久久午夜精品| 欧美成人精品1314www| 欧美精品三级日韩久久| 在线观看视频一区二区| 成人精品视频一区| 国产99久久久国产精品| 狠狠色丁香久久婷婷综合_中| 亚洲第一主播视频| 亚洲午夜一区二区三区| 亚洲线精品一区二区三区八戒| 亚洲女同ⅹxx女同tv| ...av二区三区久久精品| 国产女同性恋一区二区| 国产欧美日韩精品一区| 中文字幕欧美激情| 欧美国产精品中文字幕| 亚洲国产精品成人综合| 国产精品女同互慰在线看| 国产色产综合产在线视频| 国产性做久久久久久| 国产情人综合久久777777| 日本一区二区三区dvd视频在线 | 678五月天丁香亚洲综合网| 欧美日韩电影在线播放| 欧美日韩精品一区二区天天拍小说 | 国产亚洲1区2区3区| 日本一区二区三区四区| 国产精品久久久久久久久动漫| 综合久久一区二区三区| 亚洲自拍偷拍av| 日韩激情一区二区| 久久99精品久久久久久动态图| 国产精品中文字幕欧美| av电影天堂一区二区在线观看| 91在线观看视频| 在线精品视频免费观看| 91精品一区二区三区在线观看| 精品国产制服丝袜高跟| 国产人伦精品一区二区| 亚洲乱码中文字幕综合| 午夜精品福利视频网站| 久久精品国产**网站演员| 成人一区二区在线观看| 欧洲亚洲精品在线| 日韩欧美一卡二卡| 亚洲欧美在线aaa| 日韩精品免费视频人成| 国产盗摄视频一区二区三区| 色狠狠一区二区| 欧美不卡在线视频| 综合分类小说区另类春色亚洲小说欧美| 亚洲国产精品一区二区久久恐怖片| 秋霞影院一区二区| 成人av先锋影音| 69精品人人人人| 中文字幕 久热精品 视频在线| 亚洲午夜av在线| 国产精品系列在线播放| 欧洲av在线精品| 久久日韩粉嫩一区二区三区| 一区二区三区欧美在线观看| 麻豆国产精品一区二区三区 | 午夜欧美大尺度福利影院在线看| 国产一区二区三区在线观看免费视频| www.欧美日韩| 日韩欧美卡一卡二| 一区二区三区色| 国产寡妇亲子伦一区二区| 欧美卡1卡2卡| 亚洲人xxxx| 国产成人在线观看| 欧美一区二区三区在线看| 亚洲欧美日韩国产综合在线| 国产最新精品精品你懂的| 一本色道久久综合亚洲aⅴ蜜桃| 精品成人在线观看| 亚洲成人av资源| 91视视频在线观看入口直接观看www | 8x8x8国产精品| 亚洲美女屁股眼交| 国产91综合网| 久久综合狠狠综合久久激情| 五月婷婷综合激情| 91福利精品第一导航| 国产日韩欧美精品综合| 麻豆91精品91久久久的内涵| 欧美日韩免费观看一区二区三区| 国产精品福利影院| 国产伦精品一区二区三区免费迷 | 亚洲国产精品激情在线观看| 麻豆国产精品视频| 91精品国产手机| 亚洲一区二区三区在线| av网站免费线看精品| 日本一区二区视频在线| 国产精品99久| 久久综合久久鬼色中文字| 国产一区二区三区日韩| 精品国产在天天线2019| 精品一区二区三区免费播放 |