单链表之一元多项式求和C++实现
单链表之一元多项式求和
一元多项式求和单链表实现伪代码
1、工作指针 pre、p、qre、q 初始化
2、while(p 存在且 q 存在)执行下列三种情况之一:
2.1、若 p->exp < q->exp:指针 p 后移;
2.2、若 p->exp > q->exp,则
2.2.1、将结点 q 插到结点 p 之前
2.2.2、指针 p 指向他原指结点的下一个结点;
2.3、若 p->exp == q->exp,则
2.3.1、p->coef = p->coef + q->coef
2.3.2、若 p->coef == 0,则执行下列操作,否则指针 p 后移,
2.3.2.1、删除结点 p
2.3.2.2、使指针 p 指向它原指结点的下一个结点
2.3.3、删除结点 q
2.3.4、使指针 q 指向它原指结点的下一个结点
3、如果 q 不为空,将结点 q 链接在第一个单链表的后面。
一、一元多项式求和单链表实现头文件:PolynomialOfOneIndeterminateAdd.h
//一元多项式求和头文件
#include<iostream>
using namespace std;
template<class DataType>
//定义单链表结点
struct Node
{
//数据域:非零项的系数和指数
DataType coef, exp;
//指针域
Node<DataType> *next;
};
//定义存放一元多项式的类
template<class DataType>
class Linklist
{
private:
Node<DataType> *first;
//一元多项式的项数
int size;
public:
//构造函数
Linklist();
//初始化一元多项式
void Init();
//输出一元多项式
void Print();
//定义一元多项式的的加法操作
Linklist<DataType> operator+(Linklist &p2);
}; //构造函数
template<class DataType>
Linklist<DataType>::Linklist()
{
first = new Node<DataType>;
first = NULL;
size = ;
} //实现一元多项式单链表的初始化
template<class DataType>
void Linklist<DataType>::Init()
{
cout << "多项式的元素个数为:";
cin >> size;
DataType x, y;
cout << "请输入第1项的系数:";
cin >> x;
cout << "请输入第1项的指数:";
cin >> y;
Node<DataType> *m;
m = new Node<DataType>;
m->coef = x;
m->exp = y;
m->next = NULL;
first = m;
for (int i = ; i <= size; i++)
{
cout << "请输入第" << i << "项的系数:";
cin >> x;
cout << "请输入第" << i << "项的指数:";
cin >> y;
Node<DataType> *n;
n = new Node<DataType>;
n->coef = x;
n->exp = y;
n->next = NULL;
m->next = n;
m = n;
}
} //实现一元多项式单链表实的输出
template<class DataType>
void Linklist<DataType>::Print()
{
Node<DataType> *m = first;
while (m != NULL)
{
if (m == first)
{
if (m->coef != && m->exp != )
{
cout << m->coef << "x^" << m->exp;
}
else if (m->coef != && m->exp == )
{
cout << m->coef;
}
}
else
{
if (m->coef > && m->exp != ){
cout << "+" << m->coef << "x^" << m->exp;
}
else if (m->coef< && m->exp != )
{
cout << m->coef << "x^" << m->exp;
}
else if (m->coef> && m->exp == )
{
cout << "+" << m->coef;
}
else if (m->coef < && m->exp == )
{
cout << m->coef;
}
}
m = m->next;
}
cout << endl;
} //实现一元多项式单链表的相加
template<class DataType>
Linklist<DataType> Linklist<DataType>::operator+(Linklist &p2)
{
//声明工作指针
Node<DataType> *pre, *p, *qre, *q;
//初始化工作指针
pre = this->first;
p = pre->next;
qre = p2.first;
q = qre->next;
while (p != NULL&&q != NULL)
{
//p->exp < q->exp:指针 p 后移
if (p->exp < q->exp)
{
pre = p;
p = p->next;
}
//p->exp > q->exp:将结点 q 插到结点 p 之前,指针 p 指向他原指结点的下一个结点
if (p->exp > q->exp)
{
Node<DataType> *s;
s = q->next;
pre->next = q;
q->next = p;
q = s;
}
//p->exp == q->exp:
if (p->exp == q->exp)
{
//p->coef = p->coef + q->coef
p->coef = p->coef + q->coef;
if (p->coef == )
{
//使指针 p 指向它原指结点的下一个结点
pre->next = p->next;
//删除结点 p
delete p;
p = p->next;
}
else
{
pre = p;
p = pre->next;
}
//使指针 q 指向它原指结点的下一个结点
qre->next = q->next;
//删除结点 q
delete q;
q = qre->next;
}
}
//如果 q 不为空,将结点 q 链接在第一个单链表的后面。
if (q != NULL)
{
pre->next = q;
delete p2.first;
}
return *this;
}
二、测试一元多项式单链表实现的源程序:TestPolynomialOfOneIndeterminateAdd.cpp
#include<iostream>
//引入一元多项式之单链表实现的头文件
#include "PolynomialOfOneIndeterminateAdd.h"
using namespace std; int main()
{
//声明一元多项式单链表
Linklist<int> p1, p2, p3;
cout << "请按指数由小到大的顺序定义多项式A(x):" << endl;
p1.Init();
cout << "输入的多项式A(x)为:";
p1.Print();
cout << "\n请按指数由小到大的顺序定义多项式B(x):" << endl;
p2.Init();
cout << "输入的多项式B(x)为:";
p2.Print();
//一元多项式相加
p3 = p1 + p2;
cout << "\n多项式A(x)和多项式B(x)的和为:" << endl;
p3.Print();
return ;
}
三、运行示例结果

单链表之一元多项式求和C++实现的更多相关文章
- leetcode 题解 Add Two Numbers(两个单链表求和)
题目: You are given two linked lists representing two non-negative numbers. The digits are stored in r ...
- 数据结构 C++ 单链表 一元多项式的相加
#include <iostream> using namespace std; struct Node { double coe; //系数 int exp; //指数 Node *ne ...
- PTA基础编程题目集6-6求单链表结点的阶乘和(函数题)
本题要求实现一个函数,求单链表L结点的阶乘和.这里默认所有结点的值非负,且题目保证结果在int范围内. 函数接口定义: int FactorialSum( List L ); 其中单链表List的定义 ...
- 时间复杂度分别为 O(n)和 O(1)的删除单链表结点的方法
有一个单链表,提供了头指针和一个结点指针,设计一个函数,在 O(1)时间内删除该结点指针指向的结点. 众所周知,链表无法随机存储,只能从头到尾去遍历整个链表,遇到目标节点之后删除之,这是最常规的思路和 ...
- 单链表的C++实现(采用模板类)
采用模板类实现的好处是,不用拘泥于特定的数据类型.就像活字印刷术,制定好模板,就可以批量印刷,比手抄要强多少倍! 此处不具体介绍泛型编程,还是着重叙述链表的定义和相关操作. 链表结构定义 定义单链表 ...
- Java实现单链表的各种操作
Java实现单链表的各种操作 主要内容:1.单链表的基本操作 2.删除重复数据 3.找到倒数第k个元素 4.实现链表的反转 5.从尾到头输出链表 6.找到中间节点 7.检测链表是否有环 8.在 ...
- [LeetCode] Linked List Cycle II 单链表中的环之二
Given a linked list, return the node where the cycle begins. If there is no cycle, return null. Foll ...
- c++单链表基本功能
head_LinkNode.h /*单链表类的头文件*/#include<assert.h>#include"compare.h"typedef int status; ...
- 单链表、循环链表的JS实现
数据结构系列前言: 数据结构作为程序员的基本知识,需要我们每个人牢牢掌握.近期我也展开了对数据结构的二次学习,来弥补当年挖的坑...... 当时上课的时候也就是跟着听课,没有亲自实现任何一种数据结 ...
随机推荐
- C# XML序列化和反序列化
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.I ...
- 容斥原理&&莫比乌斯专题
A题:A - Eddy's爱好 HDU - 2204 具体思路:如果是求n中,为平方数的有多少个,那么答案肯定是sqrt(n),同理,如果是三次根号的话,那么答案肯定是n的三分之一次方.然后继续按 ...
- tensorflow环境安装
tensorflow环境安装1.安装虚拟机Virtrualbox下载地址:https://www.virtualbox.org/wiki/Downloads 2.下载安装Ubuntu镜像下载地址:ht ...
- UNIX环境高级编程 第14章 高级I/O
这一章涉及很多概念和函数,包括:非阻塞I/O.记录锁.I/O复用.异步I/O.readv和writev函数以及内存映射. 非阻塞I/O 在Unix中,可以将系统调用分为两种,一种是“低速”系统调用,另 ...
- 查看linux系统的信息
#!/bin/sh ################################################## #function:get host's information #Autho ...
- WCF REST 工作总结
首先引用System.ServiceModel;System.ServiceModel;System.ServiceModel.Activation;命名空间 [ServiceContract] pu ...
- rollup&&cube
group by 擴展 rollup&&cube --按job分組計算不同job的匯總工資 SELECT job, SUM (sal) FROM emp GROUP BY ...
- java连接redis无法连接,报异常RedisConnectionException
不管是spring还是原生jedis连接redis,如果连不上多半是linux服务器的问题: 1 首先确保redis端口开放: 把6379或者redis的端口开放即可 2 redis.conf配置注释 ...
- error while loading shared libraries: libtest.so: cannot open shared object file: No such file or directory
一般我们在Linux下执行某些外部程序的时候可能会提示找不到共享库的错误, 比如: tmux: error while loading shared libraries: libevent-1.4.s ...
- 01 Go 1.1 Release Notes
Go 1.1 Release Notes Introduction to Go 1.1 Changes to the language Integer division by zero Surroga ...