顺序线性表之大整数求和C++
顺序线性表之大整数求和
大整数求和伪代码
1、初始化进位标志 flag=0;
2、求大整数 A 和 B 的长度:
int aLength = a.GetLength();
int bLength = b.GetLength();
3、从各位开始逐位进行第 i 位的加法,直到 A 或 B 计算完毕:
3.1、计算第 i 位的值:c.Insert(i+1, (a.GetElement(i + 1) + b.GetElement(i + 1) + flag) % 10);
3.2、计算该位的进位:flag = (a.GetElement(i + 1) + b.GetElement(i + 1) + flag) / 10;
4、计算大整数 A 或 B 余下的部分;
5、计算结果的进位
注:用数组来存放大整数
一、顺序线性表头文件:SeqList.h
//顺序线性表的头文件
#include<iostream>
const int MaxSize = 100;
//定义顺序表SeqList的模板类
template<class DataType>
class SeqList{
public:
//顺序表无参构造器(创建一个空的顺序表)
SeqList(){ length = 0; }
//顺序表有参构造器(创建一个长度为n的顺序表)
SeqList(DataType array[], int n);
//顺序表析构函数
~SeqList(){}
//求顺序表的长度
int GetLength(){ return length; }
//顺序表按位查找,返回i位置的元素
DataType GetElement(int i);
//顺序表按值查找,返回该元素所在的位置
int GetLocal(DataType x);
//顺序表在指定的位置插入指定的元素
void Insert(int i, DataType x);
//顺序表删除元素,返回删除的元素
DataType Delete(int i);
//输出顺序表中的元素
void PrintSeqList();
private:
//一维数组,存放数据元素
DataType data[MaxSize];
//顺序表的长度
int length;
};
//实现顺序表有参构造器
template<class DataType>
SeqList<DataType>::SeqList(DataType array[], int n)
{
if (n > MaxSize)
{
throw "传入的顺序表长度过长";
}
//给顺序表的存储元素的数组赋值
for (int i = 0; i < n; i++)
{
data[i] = array[i];
}
//给顺序表的长度赋值
length = n;
}
//实现顺序表按位查找
template<class DataType>
DataType SeqList<DataType>::GetElement(int i)
{
//判断是定的位置是否合理
if (i < 1 || i >length)
{
throw "位置有误";
}
else
{
//返回指定位置的元素
return data[i - 1];
}
}
//实现顺序表按值查找,返回该元素所在的位置
template<class DataType>
int SeqList<DataType>::GetLocal(DataType x)
{
//遍历顺序表的元素
for (int i = 0; i < length; i++)
{
//判断指定的元素是否在顺序表中
if (data[i] == x)
{
//返回指定元素在顺序表中的位置
return (i + 1);
}
}
//如果指定的元素不在顺序表中,则返回位置为0
return 0;
}
//实现顺序表插入元素
template<class DataType>
void SeqList<DataType>::Insert(int index, DataType x)
{
//判断插入的位置是否合理
if (length >= MaxSize)
{
throw "顺序表已存放满";
}
if (index<1 || index>length + 1)
{
throw "插入元素的位置有误";
}
//如何插入的位置合理,则把顺序表中从最后位置到指定插位置的元素整体向后移动一个位置
for (int j = length; j >= index; j--)
{
data[j] = data[j - 1];
}
//给插入的位置放入指定的元素
data[index - 1] = x;
length++;
}
//实现顺序表删除指定位置的元素
template<class DataType>
DataType SeqList<DataType>::Delete(int index)
{
//声明要取出的元素
DataType x;
//判断要删除的位置是否合理
if (index<1 || index>length)
{
throw "删除的位置有误";
}
else
{
//取出指定位置的元素
x = data[index - 1];
//将指定位置后的元素全部都向前移动一个位置
for (int i = index; i < length; i++)
{
data[i - 1] = data[i];
}
//删除顺序表中的元素后,其长度减1
length--;
}
return x;
}
//顺序输出顺序表中的元素
template<class DataType>
void SeqList<DataType>::PrintSeqList()
{
if (length < 1)
{
throw "顺序表中没有元素";
}
else
{
//顺序输出顺序表元素
for (int i = 0; i < length; i++)
{
cout << data[i] << " ";
}
cout << endl;
}
}
二、大整数求和头文件:BidIntegerAdd.h
//顺序线性表之大整数求和
#include<iostream>
//引入顺序线性表的头文件
#include"SeqList.h"
using namespace std;
SeqList<int> Add(SeqList<int>a, SeqList<int>b)
{
//定义中间变量,顺序线性表
SeqList<int> c = SeqList<int>();
//flag 是进位标志,i 为大整数的某一位
int flag = 0, i = 0;
//求大整数 a,b 的位数
int aLength = a.GetLength();
int bLength = b.GetLength();
//逐位计算加法直到某个大整数计算完毕
while (i < aLength&&i < bLength)
{
//计算第 i 位的值
c.Insert(i+1, (a.GetElement(i + 1) + b.GetElement(i + 1) + flag) % 10);
//计算第 i 位的进位
flag = (a.GetElement(i + 1) + b.GetElement(i + 1) + flag) / 10;
i++;
}
//计算大整数 A 余下的部分
for (; i < aLength; i++)
{
c.Insert(i + 1, (a.GetElement(i + 1) + flag) % 10);
flag = (a.GetElement(i + 1) + flag) / 10;
}
//计算大整数 B 余下的部分
for (; i < bLength; i++)
{
c.Insert(i + 1, (b.GetElement(i + 1) + flag) % 10);
flag = (b.GetElement(i + 1) + flag) / 10;
}
//如果最后有进位,则结果会多一位
if (flag == 1)
{
c.Insert(c.GetLength()+1, 1);
}
return c;
}
三、测试顺序线性表之大整数求和:TestBigIntegerAdd.h
//测试顺序线性表之大整数求和
#include<iostream>
//引入顺序表之大整数求和头文件
#include"BigIntegerAdd.h"
using namespace std;
int main()
{
//定义两个顺序线性表
int array1[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
int array2[] = { 1, 1, 1, 1, 1, 1, 1, 1 };
SeqList<int>a = SeqList<int>(array1,9);
cout << "第一个大整数是:" << endl;
a.PrintSeqList();
SeqList<int>b = SeqList<int>(array2,8);
cout << "第二个大整数是:" << endl;
b.PrintSeqList();
SeqList<int>c = Add(a, b);
cout << "他们的和是:" << endl;
c.PrintSeqList();
return 0;
}
顺序线性表之大整数求和C++的更多相关文章
- 顺序线性表之大整数求和C++实现
顺序线性表之大整数求和 大整数求和伪代码 1.初始化进位标志 flag=0: 2.求大整数 A 和 B 的长度: int aLength = a.GetLength(); int bLength = ...
- 线性表&顺序线性表
第二章 线性表 参考文献:[数据结构(C语言版)].严蔚敏 本篇章仅为个人学习数据结构的笔记,不做任何用途. 2.1 线性结构的特点 (1). 存在唯一的一个被称为"第一个"的数据 ...
- 顺序线性表 ---- ArrayList 源码解析及实现原理分析
原创播客,如需转载请注明出处.原文地址:http://www.cnblogs.com/crawl/p/7738888.html ------------------------------------ ...
- C语言数据结构-顺序线性表的实现-初始化、销毁、长度、查找、前驱、后继、插入、删除、显示操作
1.数据结构-顺序线性表的实现-C语言 #define MAXSIZE 100 //结构体定义 typedef struct { int *elem; //基地址 int length; //结构体当 ...
- 动态分配的顺序线性表的十五种操作—C语言实现
线性表 定义:是最常用的,也是最简单的数据结构,是长度为n个数据元素的有序的序列. 含有大量记录的线性表叫文件 记录:稍微复杂的线性表里,数据元素为若干个数据项组成,这时把一个数据元素叫记录 结构特点 ...
- php 顺序线性表
<?php /* * 线性顺序表 ,其是按照顺序在内存进行存储,出起始和结尾以外都是一一连接的(一般都是用一维数组的形式表现) * * GetElem: 返回线性表中第$index个数据元素 * ...
- 数据结构 - 静态顺序线性表的实行(C语言)
数据结构 - 静态顺序线性表的实行(C语言) 1 获取元素操作 对于线性表的顺序存储结构来说,如果我们要实现GetElem操作,即将线性表L中的第i个位置元素值返回,其实是非常简单的. 只要i的数值在 ...
- C算法与数据结构-线性表的应用,多项式求和---ShinePans
/*---上机作业作业,二项式加法---*/ /*---By 潘尚 ---*/ /*---日期: 2014-5-8 . ---*/ /*---题目:---*/ //如果有两个稀疏多项式A和B,设计算法 ...
- C语言实现顺序表的基本操作(从键盘输入 生成线性表,读txt文件生成线性表和数组生成线性表----三种写法)
经过三天的时间终于把顺序表的操作实现搞定了.(主要是在测试部分停留了太长时间) 1. 线性表顺序存储的概念:指的是在内存中用一段地址连续的存储单元依次存储线性表中的元素. 2. 采用的实现方式:一段地 ...
随机推荐
- ASP.NET连接数据库配置文件
// Web.Config <?xml version="1.0" encoding="utf-8"?> <!-- 有关如何配置 ASP.NE ...
- ABP文档 - Quartz 集成
文档目录 本节内容: 简介 安装 创建工作 调度工作 更多 简介 Quartz 是一个功能完整的开源工作调度系统,可用于最小的应用到一个大型的企业系统.Abp.Quartz 包简单地把Quartz集成 ...
- 网易云直播SDK使用总结
前言: 最近公司的项目中加入中直播这部分的功能,现在的直播平台真的很多很多,以前在朋友圈看到过这张图片,没办法一次性给大家看,就只能这样截成几张给大家看看.其实按照我自己的看法,现在的直播已经没办法做 ...
- Gulp自动构建Web前端程序
这两天在一个朋友在项目上碰到了一个这样的问题,在运营过程中,用户在浏览器上对某个表单进行数据提交时,需要引入新的平台接口数据的业务,通过评估,开发团队马上修改了相关后台代码和部分的前端脚本代码,通过简 ...
- HP DL388 gen9服务器安装RHEL 6.5系统
测试: 1.默认UEFI模式,F10下智能安装,如果选择自己划分分区,进入该选项后会看到系统自动就帮我们创建了一个/efi 的500M分区,一开始我就是被这个分区坑了的,要知道服务每次重启都要等很久的 ...
- lxc.conf解析&lxc容器能力
lxd启动容器实际是生成lxc.conf.剩下的就是LXC对容器进行控制了.所以可认为lxc.conf就是lxd和lxc之间主要的接口.lxc.conf详细属性参考: http://manpages. ...
- php写购物车(思路&源码)
本文介绍一个php实现的购物车代码,功能实现完整,具有一定的参考价值 这里我们为你提供个简单的php购物车代码,从增加购物产品与发生购买了,在商城开发中,这个功能是少不了的 具体分析如下: 对购物车里 ...
- JavaScript中冒泡排序
在我大学的时候,就已经接触到过很多的排序方式,只是那时候听得还很懵懂,大概知道这么个东西,也对冒泡排序有点印象,但真要我写,我是写不出来的.最近,在回顾js基础的时候,又接触到了冒泡排序.于是,就把冒 ...
- inline元素的margin与padding
替换元素与非替换元素 替换元素(replaced element):所谓替换元素就是浏览器根据元素的标签和属性,来决定元素具体显示什么内容.比如说:img标签的src属性的值用来读取图片信息并且显示出 ...
- 使用C#操作文件
读写文本文件 使用C#读写文本文件需要5个步骤: 1.创建文件流 2.创建阅读器或者写入器 3.执行读写操作 4.关闭阅读器或者写入器 5.关闭文件流 例 using System; using Sy ...