一元稀疏多项式计算器

news/2024/11/25 9:30:20/

别把自己太当回事,要把你做的事当回事!💓💓💓

文章目录

    • 1、问题描述
    • 2、问题分析
    • 3、源代码图解分析
    • 4、完整源代码
    • 结语

1、问题描述

问题描述】设计一个一元稀疏多项式得简单计算器。
基本要求】采用带头结点的单链表存储一元稀疏多项式,设计实现简单计算器以下基本功能。
(1)输入并且建立多项式。
(2)一元多项式的相加运算。
(3)一元多项式的相减运算。
(4)一元多项式的相乘运算。
(5)一元多项式的求导运算。

👇👇👇
💘💘💘知识连线时刻(直接点击即可)

  🎉🎉🎉复习回顾🎉🎉🎉
    链表复习回顾

测试数据
输入数据:第一个多项式A,共5项,分别是(6,0)(2,1)(8,7)(4,15)(3,18);第二个多项式B,共3项,分别是(7,1)(2,6)(-8,7)。
输出数据:
A多项式的结果:6 + 2X + 8X ^ 7 + 4X ^ 15 + 3X ^ 18
B多项式的结果:7X + 2X ^ 6 - 8X ^ 7
多项式A + B的结果:6 + 9X + 2X ^ 6 + 4X ^ 15 + 3X ^ 18
多项式A - B的结果:6 - 5X - 2X ^ 6 + 16X ^ 7 + 4X ^ 15 + 3X ^ 18
多项式A * B的结果:42X + 14X ^ 2 + 12X ^ 6 - 44X ^ 7 + 40X ^ 8 + 16X ^ 13 - 64X ^ 14 + 28X ^ 16 + 21X ^ 19 + 8X ^ 21 - 32X ^ 22 + 6X ^ 24 - 24X ^ 25
多项式A的导数结果:2 + 56X ^ 6 + 60X ^ 14 + 54X ^ 17

2、问题分析

这里小编提供一种思路哈:
1、首先我们要清楚这是需要建立带哨兵位头节点的单链表;每个节点里面存两个数据,一个是指数,一个是系数。
2、其次就是需要注意多项式输出的时候需要注意的各种情况,这里需要考虑完整,例如:系数小于0时,指数为1时等等。
3、接下来就到了,多项式计算环节,这里就需要用到数学上计算功底了,这里面需要注意。

3、源代码图解分析

具体细节操作还得看源码:(小编这里先拿图片对各个分文件里面重要环节做详解,之后再附上完整源代码

首先看头文件中的代码:(Many.h)

在这里插入图片描述

其次来看看源文件:(Many.cpp)

输出打印多项式函数

在这里插入图片描述

插多项式入函数:

在这里插入图片描述

A+B函数:

在这里插入图片描述

A-B函数:

在这里插入图片描述

A*B函数:

在这里插入图片描述

A的导数函数:

在这里插入图片描述

最后是主函数源代码(test.cpp)

在这里插入图片描述

4、完整源代码

上面的图解分析,小编是对该程序分文件操作,然后小编对其每个文件中重点函数进行分析展现,这里为了大家方便看源代码,小编也将其放在一个源文件中并且依然能正确运行:


#include <stdio.h>
#include <assert.h>
#include <stdlib.h>typedef int SLDataType;typedef struct List
{SLDataType data;//存系数SLDataType val;//存指数struct List* next;
}LS, LN;LS* ListInit();//链表初始化(实际建立哨兵位头节点)void ListPushBack(LS* Phead, SLDataType x, SLDataType y);//尾插构建链表void PrintPloy(LS* Phead);//输出多项式void AddPloy(LS* Pheada, LS* Pheadb, LS* AddPhead);//A+Bvoid SubPloy(LS* Pheada, LS* Pheadb, LS* SubPhead);//A-Bvoid MulPloy(LS* Pheada, LS* Pheadb, LS* MulPhead);//A*Bvoid DerPloy(LS* Pheada, LS* DerPhead);//A的导数//创建结点
LS* BuyNode(SLDataType x, SLDataType y)
{LS* newnode = (LS*)malloc(sizeof(LS));if (newnode == NULL){printf("malloc fail\n");exit(-1);}newnode->data = x;//存系数newnode->val = y;//存指数newnode->next = NULL;return newnode;
}//初始化建立哨兵位头节点
LS* ListInit()
{LS* Phead = BuyNode(0, 0);Phead->next = Phead;return Phead;
}
//尾插构建链表
void ListPushBack(LS* Phead, SLDataType x, SLDataType y)
{assert(Phead);LS* newnode = BuyNode(x, y);//单向循环,因此找尾部LS* tail = Phead->next;while (tail->next != Phead){tail = tail->next;}tail->next = newnode;newnode->next = Phead;
}
//输出打印多项式
void PrintPloy(LS* Phead)
{int count = 1;LS* tail = Phead->next;assert(Phead);while (tail != Phead){if (tail->data == 0)//系数为0{tail = tail->next;continue;}if (tail->val == 0 )//指数为0{printf("%d", tail->data);}if (tail->data > 0 && tail->val > 0)//系数大于0输出{if (count != 1)printf(" + ");if (tail->val == 1)//指数为1时输出{if (tail->data == 1.0)printf("X");//系数为1时输出elseprintf("%dX", tail->data);}else//指数大于1的时候输出{if (tail->data == 1.0)printf("X^%d", tail->val);elseprintf("%dX^%d", tail->data, tail->val);}}if (tail->data < 0 && tail->val > 0)//系数小于0输出{if (count != 1)printf(" - ");if (tail->val == 1)//指数为1时输出{if (tail->data == 1.0)printf("X");//系数为1时输出elseprintf("%dX", tail->data * (-1));}else//指数大于1的时候输出{if (tail->data == 1.0)printf("X^%d", tail->val);elseprintf("%dX^%d", tail->data * (-1), tail->val);}}count = 0;tail = tail->next;}
}int cmp(SLDataType a, SLDataType b)
{if (a > b)return 1;else if (a == b)return 0;elsereturn -1;
}
//将运算后的结果插入
void Insert(LS* AddPhead, SLDataType x, SLDataType y)//x是指数,y是系数
{LS* cur = AddPhead;assert(AddPhead);while (cur->next != AddPhead && cmp(cur->next->val, x) < 0){cur = cur->next;}if (cur->next != AddPhead && cmp(cur->next->val, x) == 0){cur->next->data += y;}else{LS* newnode = (LS*)malloc(sizeof(LS));if (newnode == NULL){printf("malloc fail\n");exit(-1);}newnode->data = y;newnode->val = x;newnode->next = cur->next;cur->next = newnode;}
}
//实现A+B
void AddPloy(LS* Pheada, LS* Pheadb, LS* AddPhead)
{LS* str = Pheadb->next;LS* cur = Pheadb->next;assert(Pheada && Pheadb && AddPhead);for (cur = Pheada->next; cur != Pheada; cur = cur->next){Insert(AddPhead, cur->val, cur->data);}for (str = Pheadb->next; str != Pheadb; str = str->next){Insert(AddPhead, str->val, str->data);}
}//A-B
void SubPloy(LS* Pheada, LS* Pheadb, LS* SubPhead)
{LS* str = Pheadb->next;LS* cur = Pheada->next;assert(Pheada && Pheadb && SubPhead);for (cur = Pheada->next; cur != Pheada; cur = cur->next)//将A插入{Insert(SubPhead, cur->val, cur->data);}for (str = Pheadb->next; str != Pheadb; str = str->next)//将B插入{str->data = -(str->data);//将B的系数变为负值Insert(SubPhead, str->val, str->data);str->data = -(str->data);//将B的系数变为原值}
}
//A*B
void MulPloy(LS* Pheada, LS* Pheadb, LS* MulPhead)
{int a = 0, b = 0;LS* cur = Pheada->next;LS* str = Pheadb->next;LS* prev = Pheada;assert(Pheada && Pheadb && MulPhead);for (cur = Pheada->next; cur != Pheada; cur = cur->next){for (str = Pheadb->next; str != Pheadb; str = str->next){a = (cur->data) * (str->data);//系数相乘b = (cur->val) + (str->val);//指数相加Insert(MulPhead, b, a);//将运算后的结果插入}}
}
//A的导数
void DerPloy(LS* Pheada, LS* DerPhead)
{LS* cur = Pheada->next;assert(Pheada);for (cur = Pheada->next; cur != Pheada; cur = cur->next){if (cur->val == 0)//判断指数是否为0{cur->data = 0;}else{cur->data *= cur->val;//系数与指数相乘cur->val = cur->val - 1;}Insert(DerPhead, cur->val, cur->data);//将结果插入}
}int main()
{LS* Pa = ListInit();//存放A多项式LS* Pb = ListInit();//存放B多项式LS* Add = ListInit();//存放A+B多项式LS* Sub = ListInit();//存放A-B多项式LS* Mul = ListInit();//存放A*B多项式LS* Der = ListInit();//存放A的导数size_t n = 0, m = 0;int a = 0, b = 0, c = 0, d = 0;printf("A多项式的项数:");scanf("%d", &n);//A的项数for (size_t i = 1; i <= n; i++){printf("A多项式的第%d项系数和指数:", i);scanf("%d %d", &a, &b);ListPushBack(Pa, a, b);}printf("A多项式的输出:");PrintPloy(Pa);printf("\n");printf("B多项式的项数:");scanf("%d", &m);for (size_t i = 1; i <= m; i++){printf("B多项式的第%d项系数和指数:", i);scanf("%d %d", &c, &d);ListPushBack(Pb, c, d);}printf("B多项式的输出:");PrintPloy(Pb);printf("\n");AddPloy(Pa, Pb, Add);printf("多项式A+B的输出:");PrintPloy(Add);printf("\n");printf("多项式A-B的输出:");SubPloy(Pa, Pb, Sub);PrintPloy(Sub);printf("\n");printf("多项式A*B的输出:");MulPloy(Pa, Pb, Mul);PrintPloy(Mul);printf("\n");printf("多项式A的导数输出:");DerPloy(Pa, Der);PrintPloy(Der);printf("\n");return 0;
}

运行截图:
在这里插入图片描述

结语

这次也是一个小小的实验,是一元稀疏多项式计算器的实现,能够实现对两个多项式进行简单的计算处理即可。以上只是vince提供的一种方法,当然也还有很多不足之处,也望大家批评指正。
在这里插入图片描述
🎉🎉🎉以上代码均可运行,所用编译环境为 vs2019 ,运行时注意加上编译头文件#define _CRT_SECURE_NO_WARNINGS 1


http://www.ppmy.cn/news/453877.html

相关文章

一元函数的插值c语言,一元函数插值-Read.doc

一元函数插值 目标&#xff1a; 对比插值和数据拟合的思想 一元函数插值(线性插值和抛物线插值)及程序实现 基本理论 插值&#xff1a;采集到的数据可以看作是精确数据&#xff0c;要求函数或曲线通过这些数据点。 常用插值方法&#xff1a;一元函数插值(自变量只有一个)和二元…

java 一元二次方程_java一元二次方程求根

? 提高题 1) 设有一元二次方程如下: aX bx c=0 试根据从键盘输入的 a,b,c 求解方程的根。 【提示】要考虑各种情形:一是 a 为0的情形,方程根为-c/...... (理论考试重点内容实践) 一元二次方程白盒测试要求 1) 自备 C 语言程序(可从 C 语言程序设计的教科书上摘录若干典型程序,…

【基础入门题022】一元钱换成分币

【基础入门题】2021.11.18 1分钱、2分钱、5分钱组成1元钱的所有组合&#xff0c;每种分币至少一个且总币数为30。 编程语言&#xff1a;包括但不限于Python 题目来源&#xff1a;派森特给站每日刷题频道 ———————————————— 即解整数不定方程组&#xff1a; i…

java用一张一元票换一分,把一元纸币换成一分、二分、五分硬币(每种至少一枚),有多少种换法?使用递归...

Java codepublic class PayType {private static int count=0; private static int coins[]={1,2,5}; public static void main(String[] args) {int amount=1*100; int coinsCount[]=new int[coins.length]; //先每种至少一张 for(int i=coinsCount.length-1;i>=0;i--) {am…

一元分类、二元分类、多类分类、多标签学习

unary classification -- 一元分类 维基百科中的定义是&#xff1a;一类分类&#xff0c;即一元分类&#xff0c;通过仅包含该类的对象的训练数据中学习&#xff0c;试图能够在所有对象中识别该特定类的对象。 one-class classification是由[Moya & Hush][1]在1996年提出…

换分币c语言程序,编写程序输出用一元人民币兑换成1分、2分和5分硬币的不同兑换方法...

#include #include int main(){ int c1, c2, c5, cnt 0; printf("1元硬币有以下这些兑换方法&#xff1a;"); for(c1 0; c1 < 100; c1) for(c2 0; c2 < 50; c2) for(c5 0; c5 < 20; c5) if(c1 * 1 c2 * 2 c5 * 5 100){ printf("%3d个1分硬币、…

C++:将一元人民币兑换成1、2、5分的硬币,求换法

#include<iostream> //预操作 #include<cmath> using namespace std;// 使用命名空间std int main() {int i, j, k;int sum 0;int a 1, b 2, c 5;cout << "The algorithms are :" << endl;cout << "penny" << &…

Unity UGUI5——图集

一、Drawcall ​ 字面理解 DrawCall&#xff0c;就是绘制呼叫的意思&#xff0c;表示 CPU&#xff08;中央处理器&#xff09;通知 GPU&#xff08;图形处理器-显卡&#xff09; &#xff08;一&#xff09;DrawCall 概念 就是 CPU &#xff08;处理器&#xff09;准备好渲染…