c언어 다항식의 곱 에 관한 질문입니다 ...
남자
질문 제목 :
다항식의 곱에 관한 질문
* 문제
첨부된 파일 poly1_multi_problem.c 은 다항식 표현1을 사용하여 곱셈을 구현한 것이다.
소스코드를 분석하여 // write appropriate codes here. 라고 표시된 부분에
적당한 코드를 삽입하여 아래 화면과 같은 결과를 출력하는 프로그램을 완성하라.
* 주의
제일 마지막줄 출력결과는 overflow가 발생한 경우로
배열크기가 10이기 때문에 완벽한 연산결과가 저장되지 못한 경우이다.
이에 대하여 출력결과와 동일하게 동작하도록 구현할 것.
* 참고
- mult_t 함수는 다항식에 단항(예를 들어 2x^3)을 곱하는 함수이다.
- mult 함수는 다항식에 다항식을 곱하는 함수이다.
add 함수와 mult_t 함수를 사용하여 구현할 것질문 내용 :
#include stdio.h
#define max_sz 10
int add(double c1[],int s1,
double c2[],int s2)
// assume that s1=max_sz,
// s2=max_sz
{
int i=0;
for(i=0;is1 && is2;++i) {
c1[i]+=c2[i];
}
for(;is2;++i) {
c1[i]=c2[i];
}
return i;
}
int mult_t(double c1[],int s1,
double cef,int exp)
// assume that s1=max_sz
{
int s2;
int i,j;
s2=s1+exp;
for(i=s2-1,j=s1-1;j=0;--i,--j) {
if(imax_sz) c1[i]=c1[j]*cef;
}
for(;i=0;--i) {
// write appropriate codes here. (1 line)
c1[i]=0;
}
if(s2max_sz) return max_sz;
return s2;
}
int mult(double c1[],int s1,
double c2[],int s2)
// assume that s1=max_sz,
// s2=max_sz
{
double c3[max_sz],c4[max_sz];
int s3,s4=0;
int i;
for(i=0;is2;++i) {
// write appropriate codes here. (3 lines)
}
return add(c1,0,c4,s4);
}
void print_poly(double c[],int s)
// assume that s=max_sz
{
int i;
for(i=0;is;++i) {
printf(%gx^%d ,c[i],i);
}
printf(\n);
}
int main(void)
{
double c1[max_sz]={2,0,0,1};
int s1=5;
double c2[max_sz]={1,-2,3,-1,0,-2,1};
int s2=7;
double c3[max_sz]={-3,2,1};
int s3=3;
printf(c1: );
print_poly(c1,s1);
printf(c2: );
print_poly(c2,s2);
printf(c3: );
print_poly(c3,s3);
; printf(\n);
s1=add(c1,s1,c2,s2); // c1 = c1 + c2
printf(c1=c1+c2: );
print_poly(c1,s1);
s1=mult_t(c1,s1,2,3); // c1 = c1 * 2x^3
printf(c1=c1*2x^3: );
print_poly(c1,s1);
s2=mult(c2,s2,c3,s3); // c2 = c2 * c3
printf(c2=c2*c3: );
print_poly(c2,s2);
s1=mult(c1,s1,c2,s2); // c1 = c1 * c2: overflow!
printf(c1=c1*c2: );
print_poly(c1,s1);
return 0;
}
위 빨간색 라인을 수정해서 아래와 같은 결과가 나오면 되는데,,,,(c1=c1*c2 는 오버플로우발생해서 저렇게 뜨는겁니다)
3라인을 추가하면 된다는데,, 소스자체를 수정해서 구현이 가능한데,,,,3라인을 추가해서는 도저히 답이나오질않습니다 ㅠㅠ
하루종일 삽질 해서 여기까지 도움을 요청하게되었습니다
도와주세요 ㅠㅠ
-
돌심보
불필요한 덧글을 싫어하는 1인
-
큰재
다항식을 까먹은 1인
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |