- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我编写了 C 程序,其中应该添加两个多项式。我在 Kali Linux 2.0 操作系统中编写了这个程序。当我执行该程序时,我没有得到所需的输出。相反,我得到了这个-
Polynomial 1
How many no. terms do you want to enter? 1
Enter coefficient for term 1: 2
Enter exponent for term 1: 3
Polynomial 2
How many no. terms do you want to enter? 1
Enter coefficient for term 1: 2
Enter exponent for term 1: 3
Polynomial 1=
Polynomial 2=
Sum of the two polynomials is
程序代码如下-
#include<stdio.h>
#include<stdlib.h>
typedef struct node
{
int exp,coeff;
struct node *next;
}poly;
poly *headA,*headB,*headC;
poly *lastA,*lastB,*lastC;
void insert(poly*,poly*,poly *);
void input(poly *,poly *);
void display(poly *);
void insert(poly *new,poly *head,poly *last)
{
poly *p,*q;
if(head==NULL&&last==NULL) //setting the start
{
head=last=new;
return;
}
p=head;
q=NULL;
while(new->exp<p->exp)
{
q=p;
p=p->next;
}
if(p->exp==new->exp) //if exponents are equal
p->coeff=p->coeff+new->coeff;
else
{
if(q!=NULL) //insertion in middle
{
q->next=new;
new->next=p;
}
else if(q==NULL) //insertion at beginning
{
new->next=head;
head=new;
}
else if(p==NULL) //insertion at the end
{
last->next=new;
last=new;
}
}
}
void input(poly *head,poly *last)
{
int i,n,c,e;
poly *new;
new=(poly *)malloc(sizeof(poly));
printf("How many no. terms do you want to enter? ");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
printf("\nEnter coefficient for term %d: ",i);
scanf("%d",&new->coeff);
printf("Enter exponent for term %d: ",i);
scanf("%d",&new->exp);
new->next=NULL;
insert(new,head,last);
insert(new,headC,lastC);
}
}
void display(poly *start)
{
poly *p;
p=start;
while(p!=NULL)
{
printf("(%dx^%d)+",p->coeff,p->exp);
p=p->next;
}
printf("\b");
}
void main()
{
system("clear");
headA=(poly *)malloc(sizeof(poly));
headB=(poly *)malloc(sizeof(poly));
headC=(poly *)malloc(sizeof(poly));
lastA=(poly *)malloc(sizeof(poly));
lastB=(poly *)malloc(sizeof(poly));
lastC=(poly *)malloc(sizeof(poly));
headA=headB=headC=NULL;
lastA=lastB=lastC=NULL;
printf("Polynomial 1\n\n");
input(headA,lastA);
printf("\nPolynomial 2\n\n");
input(headB,lastB);
printf("\n\nPolynomial 1=");
display(headA);
printf("\nPolynomial 2=");
display(headB);
printf("\nSum of the two polynomials is=");
display(headC);
}
编辑:阅读评论后,我对代码进行了一些更改。现在输出是-
Polynomial 1
How many no. terms do you want to enter? 1
Enter coefficient for term 1: 5
Enter exponent for term 1: 6
Polynomial 2
How many no. terms do you want to enter? 2
Enter coefficient for term 1: 6
Enter exponent for term 1: 5
Enter coefficient for term 2: 7
Enter exponent for term 2: 8
Polynomial 1=(0x^0)+
Polynomial 2=(0x^0)+
Sum of the two polynomials is=(0x^0)
现在的程序代码是-
poly *insert(poly*,poly*,poly *);
poly *input(poly *,poly *);
void display(poly *);
poly *insert(poly *new,poly *head,poly *last)
{
poly *p,*q;
if(head==NULL&&last==NULL)
{
head=last=new;
return;
}
p=head;
q=NULL;
while(new->exp<p->exp)
{
q=p;
p=p->next;
}
if(p->exp==new->exp)
p->coeff=p->coeff+new->coeff;
else
{
if(q!=NULL)
{
q->next=new;
new->next=p;
}
else if(q==NULL)
{
new->next=head;
head=new;
}
else if(p==NULL)
{
last->next=new;
last=new;
}
}
return head;
}
poly *input(poly *head,poly *last)
{
int i,n,c,e;
poly *new;
printf("How many no. terms do you want to enter? ");
scanf("%d",&n);
for(i=1;i<=n;i++)
{
new=(poly *)malloc(sizeof(poly));
if(new==NULL)
{
printf("Allocation Error!!");
break;
}
printf("\nEnter coefficient for term %d: ",i);
scanf("%d",&new->coeff);
printf("Enter exponent for term %d: ",i);
scanf("%d",&new->exp);
new->next=NULL;
head=insert(new,head,last);
headC=insert(new,headC,lastC);
free(new);
}
return head;
}
void display(poly *start)
{
poly *p;
p=start;
while(p!=NULL)
{
printf("(%dx^%d)+",p->coeff,p->exp);
p=p->next;
}
printf("\b");
}
void main()
{
system("clear");
headA=(poly *)malloc(sizeof(poly));
headB=(poly *)malloc(sizeof(poly));
headC=(poly *)malloc(sizeof(poly));
lastA=(poly *)malloc(sizeof(poly));
lastB=(poly *)malloc(sizeof(poly));
lastC=(poly *)malloc(sizeof(poly));
if(headA==NULL||headB==NULL||headC==NULL||lastA==NULL||lastB==NULL||lastC==NULL)
{
printf("Allocation failure!!!");
return;
}
headA=headB=headC=NULL;
lastA=lastB=lastC=NULL;
printf("Polynomial 1\n\n");
headA=input(headA,lastA);
printf("\nPolynomial 2\n\n");
headB=input(headB,lastB);
printf("\n\nPolynomial 1=");
display(headA);
printf("\nPolynomial 2=");
display(headB);
printf("\nSum of the two polynomials is=");
display(headC);
}
最佳答案
这是一个工作版本:
#include <stdio.h>
#include <stdlib.h>
term_t
描述多项式中的单个项。
typedef struct term {
int exp;
int coeff;
struct term *next;
} term_t;
poly_t
描述了整个多项式,它只是一个项列表。 last
指针并不是真正必要的,因为我们总是从头开始遍历列表。
typedef struct poly {
term_t *head;
} poly_t;
我们需要一种通过将项列表设置为空来初始化多项式的方法。我们还需要一种通过释放多项式的所有项来销毁多项式的方法。
void init_poly(poly_t *poly)
{
poly->head = NULL;
}
void destroy_poly(poly_t *poly)
{
term_t *term = poly->head;
while (term != NULL) {
term_t *nextTerm = term->next;
free (term);
term = nextTerm;
}
poly->head = NULL;
}
我们还会发现有必要能够克隆术语(创建现有术语的副本)。请注意,在 C 中,无需强制转换 malloc
的返回值。
term_t *clone_term(term_t *term)
{
term_t *new_term;
if ((new_term = malloc(sizeof *new_term)) == NULL) {
printf("Allocation failure!!!\n");
return NULL;
}
new_term->coeff = term->coeff;
new_term->exp = term->exp;
new_term->next = NULL;
return new_term;
}
我们还需要一种将项插入多项式的方法。项按指数排序(最高指数在列表中排在前面),但如果具有匹配指数的项已经在多项式中,我们只需添加到系数即可。我们可以通过维护指向下一个指针的指针来消除所有特殊情况代码,我们将修改该指针以指向新术语。
void insert_term(poly_t *poly, term_t *term)
{
term_t **nextPtr = &poly->head;
term_t *nextTerm;
while ((nextTerm = *nextPtr) != NULL) {
if (nextTerm->exp == term->exp) {
/* we found an existing term with a matching exponent */
nextTerm->coeff += term->coeff;
free (term); /* we don't need term so it must be free'd */
return;
}
else if (nextTerm->exp < term->exp) {
/* the next term has a lower exponent, so we stop here */
break;
}
nextPtr = &nextTerm->next;
}
term->next = nextTerm;
*nextPtr = term;
}
input_poly
函数仅负责输入单个多项式。它为插入的每个术语分配一个新的 term_t
。
int input_poly(poly_t *poly)
{
int i, n;
printf("How many terms do you want to enter? ");
scanf("%d", &n);
for (i = 0; i < n; i++) {
term_t *term;
if ((term = malloc(sizeof *term)) == NULL) {
printf("Allocation failure!!!\n");
return -1;
}
printf("\nEnter coefficient for term %d: ", i+1);
scanf("%d", &term->coeff);
printf("Enter exponent for term %d: ", i+1);
scanf("%d", &term->exp);
term->next = NULL;
insert_term(poly, term);
}
return 0;
}
add_to_poly
函数将多项式添加到现有多项式中。它通过克隆加数的项并将它们插入累加器来实现这一点。有必要克隆每一项,因为一项不能同时是两个多项式的成员。请注意,由于两个多项式的指数均按排序顺序保存,因此可以更有效地完成此操作。
int add_to_poly(poly_t *accum, const poly_t *addend)
{
term_t *term;
for (term = addend->head; term != NULL; term = term->next) {
term_t *new_term;
if ((new_term = clone_term(term)) == NULL) {
return -1;
}
insert_term(accum, new_term);
}
return 0;
}
使用退格字符删除尾随的 +
可能在终端上可行,但当输出重定向到文件时则不起作用。最好只在需要时才打印分隔符。
void display_poly(poly_t *poly)
{
term_t *term;
for (term = poly->head; term != NULL; term = term->next) {
printf("(%dx^%d)", term->coeff, term->exp);
if (term->next != NULL) {
printf("+");
}
}
}
main
应该具有以下类型签名。我们只需初始化多项式,输入两个多项式,将它们相加并打印它们。
int main(int argc, char **argv)
{
poly_t polyA;
poly_t polyB;
poly_t polyC;
init_poly(&polyA);
init_poly(&polyB);
init_poly(&polyC);
printf("Polynomial 1\n\n");
if (input_poly(&polyA) == -1) {
goto error;
}
printf("\n");
printf("Polynomial 2\n\n");
if (input_poly(&polyB) == -1) {
goto error;
}
printf("\n\n");
if ((add_to_poly(&polyC, &polyA) == -1 ||
add_to_poly(&polyC, &polyB) == -1)) {
goto error;
}
printf("Polynomial 1=");
display_poly(&polyA);
printf("\n");
printf("\nPolynomial 2=");
display_poly(&polyB);
printf("\n");
printf("\nSum of the two polynomials is=");
display_poly(&polyC);
printf("\n");
error:
destroy_poly(&polyA);
destroy_poly(&polyB);
destroy_poly(&polyC);
return 0;
}
关于c - 我的多项式加法 c 代码有什么问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32301640/
我尝试理解[c代码 -> 汇编]代码 void node::Check( data & _data1, vector& _data2) { -> push ebp -> mov ebp,esp ->
我需要在当前表单(代码)的上下文中运行文本文件中的代码。其中一项要求是让代码创建新控件并将其添加到当前窗体。 例如,在Form1.cs中: using System.Windows.Forms; ..
我有此 C++ 代码并将其转换为 C# (.net Framework 4) 代码。有没有人给我一些关于 malloc、free 和 sprintf 方法的提示? int monate = ee; d
我的网络服务器代码有问题 #include #include #include #include #include #include #include int
给定以下 html 代码,将列表中的第三个元素(即“美丽”一词)以斜体显示的 CSS 代码是什么?当然,我可以给这个元素一个 id 或一个 class,但 html 代码必须保持不变。谢谢
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我试图制作一个宏来避免重复代码和注释。 我试过这个: #define GrowOnPage(any Page, any Component) Component.Width := Page.Surfa
我正在尝试将我的旧 C++ 代码“翻译”成头条新闻所暗示的 C# 代码。问题是我是 C# 中的新手,并不是所有的东西都像 C++ 中那样。在 C++ 中这些解决方案运行良好,但在 C# 中只是不能。我
在 Windows 10 上工作,R 语言的格式化程序似乎没有在 Visual Studio Code 中完成它的工作。我试过R support for Visual Studio Code和 R-T
我正在处理一些报告(计数),我必须获取不同参数的计数。非常简单但乏味。 一个参数的示例查询: qCountsEmployee = ( "select count(*) from %s wher
最近几天我尝试从 d00m 调试网络错误。我开始用尽想法/线索,我希望其他 SO 用户拥有可能有用的宝贵经验。我希望能够提供所有相关信息,但我个人无法控制服务器环境。 整个事情始于用户注意到我们应用程
我有一个 app.js 文件,其中包含如下 dojo amd 模式代码: require(["dojo/dom", ..], function(dom){ dom.byId('someId').i
我对“-gencode”语句中的“code=sm_X”选项有点困惑。 一个例子:NVCC 编译器选项有什么作用 -gencode arch=compute_13,code=sm_13 嵌入库中? 只有
我为我的表格使用 X-editable 框架。 但是我有一些问题。 $(document).ready(function() { $('.access').editable({
我一直在通过本教程学习 flask/python http://blog.miguelgrinberg.com/post/the-flask-mega-tutorial-part-i-hello-wo
我想将 Vim 和 EMACS 用于 CNC、G 代码和 M 代码。 Vim 或 EMACS 是否有任何语法或模式来处理这种类型的代码? 最佳答案 一些快速搜索使我找到了 this vim 和 thi
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 想改进这个问题?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve this
这个问题在这里已经有了答案: Enabling markdown highlighting in Vim (5 个回答) 6年前关闭。 当我在 Vim 中编辑包含 Markdown 代码的 READM
我正在 Swift3 iOS 中开发视频应用程序。基本上我必须将视频 Assets 和音频与淡入淡出效果合并为一个并将其保存到 iPhone 画廊。为此,我使用以下方法: private func d
pipeline { agent any stages { stage('Build') { steps { e
我是一名优秀的程序员,十分优秀!