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인
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2699105 | 링크더리스트 이전 링크값 출력함수. | 꼬꼬마 | 2025-06-23 |
2699078 | 정수를 한자리씩 배열에 담는 법은 어떻게 하나요.. (4) | 귀염포텐 | 2025-06-22 |
2699024 | C언어 공부하려는데 도와주세요!!! (2) | 달님 | 2025-06-22 |
2698994 | 날짜 계산하는 C 코드 짜고 있는데 꽉 막혀서 질문드립니다.. (6) | 별 | 2025-06-22 |
2698967 | 파일삭제 윈도우 폴더까지 접근하게하는 함수가 뭔가요 (2) | 샤인 | 2025-06-21 |
2698938 | c언어 메모리질문 (3) | 나래 | 2025-06-21 |
2698909 | 서비스 요청 고객 관리 프로그램 짜는것좀 도와주세요ㅜㅜ (4) | 궁수자리 | 2025-06-21 |
2698882 | 프로그래밍좀 짜주세요 (3) | 황예 | 2025-06-21 |
2698855 | 카프-라빈 알고리즘 코딩 분석좀 도와주세요.. | 꽃봄 | 2025-06-20 |
2698829 | 학점계산기 (7) | MyWay | 2025-06-20 |
2698782 | 기초적인 함수 질문이요ㅠㅠㅠㅠ | 내담 | 2025-06-20 |
2698749 | 프로그램 짜던 도중 패닉입니다...ㅜ | 파랑 | 2025-06-19 |
2698719 | 조건부컴파일 질문입니다.~ (2) | 큐트 | 2025-06-19 |