수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

행렬 소스 ^^

가을귀

2023.04.01

예전에 여기사이트에서 많이 배웠는게 어그제 같은데 ㅎㅎ
전에 행렬 곱 연산 하고 정방행렬 트랜스 인가 아무튼 그럴겁니다.
배열로 지정안하고 다 포인터로 지정했습니다.
참고 될거 같아서 올립니다.
지금은 웹프로그램으로 빠져서 ㅎㅎㅎ

//////////////////////////////matrix.h//////////////////////
matrix.h
#include stdio.h
#includestdlib.h

struct matrix {
int *armatrix;
int row;
int column;
};
extern matrix m[3];

void Input_Matrix_row_column(matrix *Input_Matrix);
void Input_Matrix_Data(matrix *Input_Matrix);
void Show_Matrix(matrix *Output_matrix);
void Operation_Add_Matrix(matrix *First_matrix, matrix *Second_Matrix, matrix *Save_Martrix);
void Operation_Mult_Matrix(matrix *First_matrix, matrix *Second_Matrix, matrix *Save_Martrix);
void Operation_Trans_Matrix(matrix *T_Matrix);
void Trans_Matrix(void);
void Mult_Matrix(void);
void Add_Matrix(void);
//////////////////////////////matrix.h//////////////////////

//////////////////////////////matrix multiplication.cpp//////////////////////
matrix multiplication.cpp
#includestdio.h
#include matrix.h

void main()
{
int choice,i;

while(1)
{
printf(Matrix- Quit=0 Multiplication=1 Addtion=2 Transposed=3 \t);//choose
scanf_s(%d,&choice);
if(choice==1)
{
Mult_Matrix();// Mult_Matrix
}
else if(choice==2)
{
Add_Matrix();// Add_Matrix
}
else if(choice==3)
{
Trans_Matrix(); // Trans_Matrix
}
else if(choice==0)
{
break;
}
}
for(i=0;i3;i++)
{
free(m[i].armatrix);
}
}
//////////////////////////////matrix multiplication.cpp////////////////////////////////////////////////////matrix.cpp//////////////////////
matrix.cpp
#include matrix.h
matrix m[3];
int Continue;
int total_1;
int total_2;
int total_3;
void Input_Matrix_row_column(matrix *Input_Matrix)
{
printf(행렬의 행의 개수를 입력하세요\t);
scanf_s(%d,&Input_Matrix-row);
printf(행렬의 열의 개수를 입력하세요\t);
scanf_s(%d,&Input_Matrix-column);
}
void Input_Matrix_Data(matrix *Input_Matrix)
{
int i,j;
for(i=0;iInput_Matrix-row;i++)
{
for(j=0;jInput_Matrix-column;j++)
{
printf(Matrix[%d][%d] =\t,i,j);
scanf_s(%d,(Input_Matrix-armatrix+i*Input_Matrix-column+j));
}
}
}
void Show_Matrix(matrix *Output_matrix)
{
int i,j;
for(i=0;iOutput_matrix-row;i++)
{
for(j=0;jOutput_matrix-column;j++)
{
printf(matrix[%d][%d]=%d\n,i,j,*(Output_matrix-armatrix+i*Output_matrix-column+j));
}
}
}
void Operation_Add_Matrix(matrix *First_matrix, matrix *Second_Matrix, matrix *Save_Martrix)
{
int i,j;
if(total_3!=(First_matrix-row*First_matrix-column))
{
total_3=First_matrix-row*First_matrix-column;
Save_Martrix-armatrix=(int *)malloc(total_3*sizeof(int));
}
Save_Martrix-row=First_matrix-row;
Save_Martrix-column=First_matrix-column;
for(i=0;iFirst_matrix-row;i++)
{
for(j=0;jFirst_matrix-column;j++)
{
*(Save_Martrix-armatrix+i*First_matrix-column+j) = *(First_matrix-armatrix+i*First_matrix-column+j) + (*(Second_Matrix-armatrix+j*Second_Matrix-column+i));
}
}
}
void Operation_Mult_Matrix(matrix *First_matrix, matrix *Second_Matrix, matrix *Save_Martrix)
{
int addtotal,i,j,k;
if(total_3!=(First_matrix-row*First_matrix-column))
{
total_3=First_matrix-row*First_matrix-column;
Save_Martrix-armatrix=(int *)malloc(total_3*sizeof(int));
}
Save_Martrix-row=First_matrix-row;
Save_Martrix-column=Second_Matrix-column;
for(i=0;iFirst_matrix-row;i++)
{
for(j=0;jSecond_Matrix-column;j++)
{
addtotal = 0;
for (k=0;kSecond_Matrix-row;k++)
{
addtotal = addtotal + *(First_matrix-armatrix+i*First_matrix-column+k) * (*(Second_Matrix-armatrix+k*Second_Matrix-column+j));
}
*(Save_Martrix-armatrix+i*Second_Matrix-column+j) = addtotal;
}
}
}
void Operation_Trans_Matrix(matrix *T_Matrix)
{
int buffer,m=0,i,j;
for(i=0,m=0;iT_Matrix-row;i++,m++)
{
fofor(j=m;jT_Matrix-column;j++)
{
buffer=*(T_Matrix-armatrix+i*T_Matrix-column+j);
*(T_Matrix-armatrix+i*T_Matrix-column+j)=*(T_Matrix-armatrix+j*T_Matrix-row+i);
*(T_Matrix-armatrix+j*T_Matrix-row+i)=buffer;
}
}
}
void Trans_Matrix(void)
{
do{
do
{
printf( Transposed Matrix \n);
Input_Matrix_row_column(&m[0]);
if(m[0].column!=m[0].row)
{
printf(행렬의 행과열의 개수를 맞쳐주세요\n);
}
}while(m[0].column!=m[0].row);
printf(-------- Matrix Input ------\n);
if(total_1!=(m[0].row*m[0].column))
{
total_1=m[0].row*m[0].column;
m[0].armatrix=(int *)realloc(m[0].armatrix,total_1*sizeof(int));
}
Input_Matrix_Data(&m[0]);
Operation_Trans_Matrix(&m[0]);
printf(-------Result Matrix-------x\n);
Show_Matrix(&m[0]);
printf(Continue Transposed Matrix? select Continue = 1 Quit = 0 \n);
scanf_s(%d,&Continue);
}while(Continue!=0);
}

// Mult_Matrix Sart.......................//
void Mult_Matrix(void)
{
printf(----------Matrix Multiplication----------\n);
do{ // 비교된 행과열을 Input, Mult , Show 실행
do // 행과 열 비교 프로그램
{
printf(First Matrix\n);
Input_Matrix_row_column(&m[0]);
printf(Second Matrix\n);
Input_Matrix_row_column(&m[1]);
if(m[0].column!=m[1].row)
{
printf(첫번째 열과 두번째 열의 개수를 맞쳐주세요\n);
}
}while(m[0].column!=m[1].row);
printf(-----First Matrix Input ---\n);
if(total_1!=(m[0].row*m[0].column))
{
total_1=m[0].row*m[0].column;
m[0].armatrix=(int *)realloc(m[0].armatrix,total_1*sizeof(int));
}
Input_Matrix_Data(&m[0]);
printf(-----second Matrix Input ---\n);
if(total_2!=(m[1].row*m[1].column))
{
total_2=m[1].row*m[1].column;
m[1].armatrix=(int *)realloc(m[1].armatrix,total_2*sizeof(int));
}
Input_Matrix_Data(&m[1]);
Operation_Mult_Matrix(&m[0],&m[1],&m[2]);
printf(-------Result Matrix-------x\n);
Show_Matrix(&m[2]);
printf(Continue Matrix Multiplication? select Continue = 1 Quit = 0 \n); //
scanf_s(%d,&Continue);
}while(Continue!=0);
}
void Add_Matrix(void)
{

printf(----------Matrix Addtion----------\n);
do{
do
{
printf(First Matrix\n);
Input_Matrix_row_column(&m[0]);
printf(Second Matrix\n);
Input_Matrix_row_column(&m[1]);
if((m[0].column!=m[1].row)||(m[0].row!=m[1].column))
{
printf(2개의 행렬의 행과 열의 개수를 맞쳐주세요\n);
}
}while((m[0].column!=m[1].row)||(m[0].row!=m[1].column));
printf(-----First Matrix Input ---\n);
if(total_1!=(m[0].row*m[0].column))
{
total_1=m[0].row*m[0].column;
m[0].armatrix=(int *)realloc(m[0].armatrix,total_1*sizeof(int));
}
Input_Matrix_Data(&m[0]);
printf(-----second Matrix Input ---\n);
if(total_2!=(m[1].row*m[1].column))
{
total_2=m[1].row*m[1].column;
m[1].armatrix=(int *)realloc(m[1].armatrix,total_2*sizeof(int));
}
Input_Matrix_Data(&m[1]);
Operation_Add_Matrix(&m[0],&m[1],&m[2]);
printf(-------Result Matrix-------x\n);
Show_Matrix(&m[2]);
printf(Continue Matrix Addtion? Continue = 1 Quit = 0 \n);
scanf_s(%d,&Continue);
}while(Continue!=0);
}
//////////////////////////////matrix.cpp//////////////////////

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

번호 제 목 글쓴이 날짜
2700095 연산문제...질문... 오빤테앵겨 2025-07-01
2700070 while문 , 3의배수 출력하는 프로그램좀 짜주세욤. 횃불 2025-07-01
2700041 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? 헛장사 2025-07-01
2700012 배열// (1) 전갈자리 2025-07-01
2699895 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) 선아 2025-06-30
2699842 질문을 너무 많이 하네여.....죄송.... (2) 해님꽃 2025-06-29
2699816 오류 질문입니다.. (1) 해비치 2025-06-29
2699763 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) 미라 2025-06-28
2699555 c언어 다항식을 입력을 했는데 왜 출력이 안될까요? 피스케스 2025-06-27
2699528 C언어 포인터연산 질문입니다. (3) 안녕나야 2025-06-26
2699476 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) 클라우드 2025-06-26
2699444 [좀 급함] system("explorer [주소] ") 문에 변수를 사용할 수 있나요? 알 2025-06-26
2699415 파일//read//와 배열 아란 2025-06-25
2699386 구조체 안에 일부분만 char 배열에 복사하려면 어떻게 해야하나요? (1) 미즈 2025-06-25
2699361 연결리스트 정렬하는 부분에 대해서 질문 드립니다 아이처럼 2025-06-25
2699304 [기초]아직 안주무시는분 계신가요..?포인터배열? 좀 도와주세요. 놀리기 2025-06-24
2699272 printf() 함수이용해서 프로그램 만들기 질문요! (5) 다가 2025-06-24
2699221 PUSH와 POP코드를 더 간단하게 어떻게 해야할까요? 파라미 2025-06-24
2699192 설치오류가 자꾸 나요 한번봐주세여~ (1) 소녀틳향기 2025-06-23
2699161 for loop안에 있는 if문 (9) Orange 2025-06-23
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com