다항식 곱셈 질문이요 급합니다 도움좀!!
다온
요약하자면 첨부파일에 있는 파일처럼 항갯수 차수 계수로 두개의 다항식 정보가 저장되있구요
그걸 불러내서 다항식의 곱을 하는 함수를 만든다음 곱한 다항식을 리턴해서 보여주는겁니다질문 내용 : 현재 진행상황은 파일에서 정보 받은후에 곱셈을 해서 p3에 넣어줬는데.. 이걸 다항식 곱셈할때에 같은 차수가 나와서 더해주는 그 알고리즘적인건 알겠는데 코드가 막히네요 어떻게 그걸 더해주면서 내림차순으로 정리해줄지..
제 코드 기본 바탕으로(곱셈 함수는 거의 바꾸셔도 됩니다 제가한게 틀린거 같아서..) 코드좀 부탁드립니다 ㅠㅠ 너무 급해서 어쩔수가없네요
#includestdio.h
#includestdlib.h
struct term{
int expo;
float coef;
};
struct poly{
int degree;
struct term *pt;
}p1,p2,p3;
void main()
{
int i;
file *fp=fopen(poly.txt,rb);
struct poly mulpoly(struct poly p1,struct poly p2);
fscanf(fp,%d,&p1.degree);
p1.pt=(struct term*)malloc(sizeof(struct term)*p1.degree*2);
printf(p1.degree 는 %d\n,p1.degree);
for(i=0; ip1.degree*2; i++)
{
if(i%2)
{
fscanf(fp,%f,&p1.pt[i/2].coef);
printf(p1.pt[%d].coef는 %f\n,i,p1.pt[i/2].coef);
}
else
{
fscanf(fp,%d,&p1.pt[i/2].expo);
printf(p1.pt[%d].expo는 %d\n,i,p1.pt[i/2].expo);
}
}
//----------------------------파일에서 읽어온 p2 입력-----------------------------------------//
fscanf(fp,%d,&p2.degree);
p2.pt=(struct term*)malloc(sizeof(struct term)*p2.degree*2);
printf(p2.degree 는 %d\n,p2.degree);
for(i=0; ip2.degree*2; i++)// degree 두배 하는 이유는 한 항당 차수 계수 두개씩 있기때문
{
if(i%2)//홀짝
{
fscanf(fp,%f,&p2.pt[i/2].coef); //홀짝
printf(p2.pt[%d].coef는 %f\n,i,p2.pt[i/2].coef);
}
else
{
fscanf(fp,%d,&p2.pt[i/2].expo);
printf(p2.pt[%d].expo는 %d\n,i,p2.pt[i/2].expo);
}
}mulpoly(p1,p2);
fclose(fp);
delete[]p1.pt;
delete[]p2.pt;}
struct poly mulpoly(struct poly p1,struct poly p2)
{
int i,j,k=0;
int a_index,b_index;
p3.pt=(struct term*)malloc(sizeof(struct term)*p1.degree*p2.degree+1); //p3 전역변수라 가능,항이 나올 최대 숫자 p1.degree*p2.degree
p3.degree=p1.degree*p2.degree+1;
for(i=0; ip3.degree+1; i++)
{
p3.pt[i].expo=0;
p3.pt[i].coef=0;
}
for(i=0; ip1.degree; i++)
{
for(j=0; jp2.degree; j++)
{
p3.pt[k].expo=p1.pt[i].expo+p2.pt[j].expo;
printf(곱셈결과p3.pt[%d].expo=%d\n,k,p3.pt[k].expo);
p3.pt[k].coef=p1.pt[i].coef*p2.pt[j].coef;
printf(곱셈결과p3.pt[%d].coef=%f\n,k,p3.pt[k].coef);
k++;
}
}return p3;
/*
while(a_index= p1.degree && b_index)
{
if(p1.degreep2.degree)
{
p3.pt[0].coef=p1.pt[0].coef;
p1.degree--;
}
else if
*/}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2685477 | 소수점이하 출력하는거요 | 널위해 | 2025-02-18 |
2685449 | printf배우고있는데요 궁금한게있어요 (8) | 꽃큰 | 2025-02-18 |
2685393 | c언어 질문이요.... | 붕붕 | 2025-02-18 |
2685365 | 윈도우7에서 visual studio c++6.0 (1) | 빛길 | 2025-02-17 |
2685317 | segmentation fault가 나요 | 가람 | 2025-02-17 |
2685292 | 다중스택질문 | 올해1살 | 2025-02-17 |
2685231 | C언어와 닷넷에 대해서 질문!! (2) | 설아 | 2025-02-16 |
2685206 | VisualBasic 과 DEV++ 의 장단점과 만든 파일 호환 가능하나요? | 에드워드 | 2025-02-16 |
2685154 | 배열 크기조절 | 해찬솔 | 2025-02-15 |
2685124 | 수정이거 제가 뭐가 잘못한거죠 ? | 아이돌 | 2025-02-15 |
2685096 | 포인터의 고수분들 모두 보세요!! 제발 ㅠ_ㅠ 헷갈려헷갈려..갈려헷.. (7) | 치킨마루 | 2025-02-15 |
2685045 | 전처리기 질문 | 치에미 | 2025-02-14 |
2685016 | 오류 좀 확인해 주시면 감사하겠습니다 | 초코맛사탕 | 2025-02-14 |
2684917 | 알고리즘을 이용한 행렬의 전치// 문제다운 문제네요. | 뿡뿡 | 2025-02-13 |
2684868 | 양방향 연결리스트에서 실행도중 죽는 이유좀 찾아주세요. (2) | 예다움 | 2025-02-13 |
2684844 | 시계프로그램인데 도저히 모르겠어요ㅠ (1) | 비내리던날 | 2025-02-12 |
2684812 | 레포트좀도와주세요ㅠㅠ (2) | 갈매빛 | 2025-02-12 |
2684780 | 채팅창 흉내내보려고하는데요 ㅜ.ㅜ (1) | 바름 | 2025-02-12 |
2684729 | 내일 시험인데 메모리 그리는것좀 도와주세요 ㅠ (1) | 상처주지마 | 2025-02-11 |
2684701 | 버퍼 관련 질문 3가지 (이전거랑 달라요) | 한국녀 | 2025-02-11 |