수다닷컴

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

밑의 희소 행렬 덧셈 문제.....

메이

2023.04.01


질문 제목 : 파일의 입력을 받아 희소 행렬의 덧셈을 하는 문제인데요...희소 행렬의 합은 두 희소 행렬 a와 b의 합을 희소 행렬 c에 저장하는 것이다.

먼저 희소 행렬의 각 항은 다음 구조체로 정의된다.

typedef struct{

int row;

int col;

int value;

} element;

그러면 희소 행렬은 다음 구조체로 정의된다.

typedef struct sparsematrix{

element data[max_terms];

int rows; // 행의 개수

int cols; // 열의 개수 int terms; // 항의 개수

} sparsematrix;

위와 같이 정의된 희소 행렬들을 가지고 두 희소 행렬의 합을 구하는 프로그램을 작성한다. (합 역시도 희소행렬로 표현한다.)
입력 입력은 파일 입력으로 하고 입력 파일의 이름은 “matrix.txt”으로 한다. 입력 파일의 첫 줄에 첫 번째 희소 행렬의 행과 열의 개수 n과 m이 공백을 사이에 두고 주어진다. 두 번째 줄에는 희소 행렬의 항의 개수 s가 주어진다. 그리고 다음 s개의 줄 각각에는 각 항의 정보인 행(r), 열(c), 값(v)이 주어진다. 그 다음 줄부터 두 번째 희소 행렬의 정보가 위와같이 주어진다. 출력 출력은 표준 출력으로 한다. 두 희소 행렬의 합 행렬의 각 항의 정보(행, 열, 값)를 한 줄에 하나씩 출력한다.
입출력의 예

sample input output for the sample input

3 3

4

0 2 1

1 0 1

1 2 2

2 1 3

3 3

3

0 2 5

1 0 3

2 2 1

0 2 6

1 0 4

1 2 2

2 1 3

2 2 1

질문 내용 :

#include stdio.h
#include stdlib.h
#define max_terms 10
typedef struct{
int row;
int col;
int value;
}element;

typedef struct sparsmatrix{
element data[max_terms];
int rows;
int cols;
int terms;
}sparsmatrix;
sparsmatrix_add2(sparsmatrix a, sparsmatrix b);
sparsmatrix print(sparsmatrix a,sparsmatrix b);

sparsmatrix_add2(sparsmatrix a, sparsmatrix b)
{
sparsmatrix c;
int ca=0, cb=0, cc=0;
if(a.rows != b.rows || a.cols != b.cols){
fprintf(stderr,희소행렬 크기에러\n);
exit(1);
}
c.rows = a.rows;
c.cols = a.cols;
c.terms = 0;

while(ca a.terms && cb b.terms){
int inda = a.data[ca].row * a.cols + a.data[ca].col;
int indb = b.data[cb].row * b.cols + b.data[cb].col;
if(inda indb) {
c.data[cc++] = a.data[ca++];
}

else if(inda == indb){
if((a.data[ca].value+
b.data[cb].value)!=0){
c.data[cc].row = a.data[ca].row;
c.data[cc].col = a.data[ca].col;
c.data[cc++].value = a.data[ca++].value+
b.data[cb++].value;
}
else
ca++;
cb++;
}
else c.data[cc++]=b.data[cb++];
}
for(;ca a.terms;)
c.data[cc++] = a.data[ca++];
for(;cb b.terms;)
c.data[cc++] = b.data[cb++];
c.terms =cc;
return c;
}
sparsmatrix print(sparsmatrix a,sparsmatrix b)
{
int i;
for(i=0;i a.rows;i++)
{
if(a.data[i].value == 0)
continue;
printf([%d,a.data[i].col);
printf(,%d,,a.data[i].row);
printf(%d]\n,a.data[i].value);
}
for(i=0;i b.rows;i++)
{
if(b.data[i].value == 0)
continue;
printf([%d,b.data[i].col);
printf(,%d,,b.data[i].row);
printf(%d]\n,b.data[i].value);
}
}

int main()
{
int cnt=0; //행렬 값 카운트
sparsmatrix m1;
sparsmatrix m2;file *fp;
fp = fopen(matrix.txt,r);

if(fp ==null){
printf(파일을 찾지 못했습니다. \n);
exit(1);
}
fscanf(fp, %d %d, &m1.rows, &m1.cols);
fscanf(fp, %d, &m1.terms);
for(cnt=0; cntm1.terms; cnt++){
fscanf(fp,%d %d %d, &m1.data[c].row, &m1.data[c].col, m1.data[c].value);
c++;
}fscanf(fp, %d %d, &m2.rows, &m2.cols);
fscanf(fp, %d, &m2.terms);
for(cnt=0; cnt m2.terms; cnt++){
fscanf(fp,%d %d %d, &m2.data[c].row, &m2.data[c].col,m2.data[c].value);
}sparsmatrix_add2(m1,m2);
print(m1,m2);
system(pause);
}소스 수정 좀 부탁드립니다....ㅠ

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
2698012 2~9가아닌수 아놀드 2025-06-13
2697980 for에 gets함수를 넣으니까 왜 반복이 안되죠 ㅜ (2) 펴라 2025-06-12
2697952 2차배열과 함수문의^^; VanilLa 2025-06-12
2697924 다차원 배열 질문있습니다 두동 2025-06-12
2697893 정올 :: 기초다지기 a9007 배열7 (문제가 이상함 -_-) 흰두루 2025-06-12
2697862 Unable......... 지정된 파일을 찾을 수 없습니다!! (1) Creator 2025-06-11
2697761 그러니까여제말은... (2) 새론 2025-06-10
2697737 정올 문제좀 풀어보신분~ 레오 2025-06-10
2697709 rand함수 질문좀요! (6) 가막새 2025-06-10
2697683 C언어 변수뒤 표시가 이해안되는게 있습니다. 소미 2025-06-10
2697660 껍데기딜 만들고 난후 어느핫키 누르면 코드검색이라도 뜨고 그다음 무반응 해결좀 (2) 움찬 2025-06-09
2697634 c언어로 감성사전 만들기! (1) 도란도란 2025-06-09
2697605 이 함수좀... agine 2025-06-09
2697574 배열 기본적인질문 (3) 민트향 2025-06-09
2697549 배열 초기화 (4) 나리 2025-06-08
2697465 수다님...^^ (2) 가론 2025-06-08
2697432 서버 만드는 함수에서 궁금한게있어요~ 파랑 2025-06-07
2697401 열혈강의 문제오류 (1) 꿈 2025-06-07
2697374 기초적인 C언어 프로그래밍 입니다. 얼 2025-06-07
2697341 좌우대칭 문제인데 Q가 입력되면 종료가 되야하는데 되지않습니다 무지개 2025-06-07
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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