编写一个程序,完成如下功能: 1)将用户输入的十进制整数字符串转化为带头结点的单链表每个结点存放一个整数位。 2)求两个整数单链表相加的结果单链表。 3)求结果单链表的中间位,如 123 的中间位为 2,1234 的中间位为 2。 本实验中设计的整数单链表的结点类型如下: typedef struct node{ int data; struct *node; }功能算法设计如下: CreateLink( NodeType *&h, char a[], int n ):创建整数单链表h。 DestroyLink( NodeType *&h ):释放整数单链表h。 DispLink( NodeType *h ):输出整数单链表h。 Add( NodeType *hl,*h2, NodeType *&h ):两整数单链表h1和h2相加得到h。 Reverse( *&h ):逆置整数单链表h。 Mid( NodeType *h ):求整数单链表h的中间位。

时间: 2023-06-09 19:04:50 浏览: 63
head ) //创建带头结点的单链表 { NodeType *tail, *p; char ch; head = (NodeType *)malloc(sizeof(NodeType)); tail = head; printf("请输入一个整数: "); while((ch = getchar()) != '\n') { p = (NodeType *)malloc(sizeof(NodeType)); p->data = (int)(ch - '0'); //将字符转换成整数 tail->next = p; tail = p; } tail->next = NULL; } NodeType *AddLink( NodeType *p, NodeType *q ) //链表相加 { NodeType *head, *tail, *s; int sum = 0, carry = 0; head = (NodeType *)malloc(sizeof(NodeType)); tail = head; p = p->next; q = q->next; while(p != NULL || q != NULL) { s = (NodeType *)malloc(sizeof(NodeType)); sum = (p ? p->data : 0) + (q ? q->data : 0) + carry; s->data = sum % 10; carry = sum / 10; tail->next = s; tail = s; if(p != NULL) p = p->next; if(q != NULL) q = q->next; } if(carry > 0) //最高位有进位 { s = (NodeType *)malloc(sizeof(NodeType)); s->data = carry; tail->next = s; tail = s; } tail->next = NULL; return head; } int GetMiddle( NodeType *head ) //获取链表中间位 { NodeType *p = head->next, *q = head->next; while(q != NULL && q->next != NULL) { p = p->next; q = q->next->next; } return p->data; } int main() { NodeType *p, *q, *r, *head; CreateLink(head); CreateLink(p); CreateLink(q); r = AddLink(p, q); printf("相加后的链表: "); while(r != NULL) { printf("%d ", r->data); r = r->next; } int mid = GetMiddle(r); printf("中间位为:%d", mid); return 0; }

相关推荐

最新推荐

recommend-type

C++实现数字转换为十六进制字符串的方法

主要介绍了C++实现数字转换为十六进制字符串的方法,涉及C++操作数字与字符串转换的相关技巧,需要的朋友可以参考下
recommend-type

ASP.NET技术在网站开发设计中的研究与开发(论文+源代码+开题报告)【ASP】.zip

ASP.NET技术在网站开发设计中的研究与开发(论文+源代码+开题报告)【ASP】
recommend-type

CycleGan和Pix2Pix是两个在图像到图像转换领域常用的深度学习模型

Cycle GAN和Pix2Pix都是强大的图像到图像的转换模型,但它们在应用场景、技术特点和训练数据要求等方面有所不同。Cycle GAN无需成对数据即可进行训练,适用于更广泛的图像转换任务;而Pix2Pix则依赖于成对数据进行训练,在处理具有明确对应关系的图像对时表现较好。在实际应用中,应根据具体任务和数据集的特点选择合适的模型。Cycle GAN广泛应用于各种图像到图像的转换任务,如风格迁移、季节变换、对象变形等。 由于其不需要成对数据的特性,Cycle GAN能够处理更广泛的图像数据集,并产生更多样化的结果。Pix2Pix是一个基于条件生成对抗网络(Conditional Generative Adversarial Networks, cGANs)的图像到图像的转换模型。它利用成对数据(即一一对应的图像对)进行训练,以学习从输入图像到输出图像的映射。Pix2Pix的生成器通常采用U-Net结构,而判别器则使用PatchGAN结构。
recommend-type

tensorflow-gpu-2.9.1-cp39-cp39-win-amd64.whl

tensorflow安装
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性

![MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性](https://picx.zhimg.com/80/v2-8132d9acfebe1c248865e24dc5445720_1440w.webp?source=1def8aca) # 1. MATLAB结构体基础** MATLAB结构体是一种数据结构,用于存储和组织相关数据。它由一系列域组成,每个域都有一个名称和一个值。结构体提供了对数据的灵活访问和管理,使其成为组织和处理复杂数据集的理想选择。 MATLAB中创建结构体非常简单,使用struct函数即可。例如: ```matlab myStruct
recommend-type

详细描述一下STM32F103C8T6怎么与DHT11连接

STM32F103C8T6可以通过单总线协议与DHT11连接。连接步骤如下: 1. 将DHT11的VCC引脚连接到STM32F103C8T6的5V电源引脚; 2. 将DHT11的GND引脚连接到STM32F103C8T6的GND引脚; 3. 将DHT11的DATA引脚连接到STM32F103C8T6的GPIO引脚,可以选择任一GPIO引脚,需要在程序中配置; 4. 在程序中初始化GPIO引脚,将其设为输出模式,并输出高电平,持续至少18ms,以激活DHT11; 5. 将GPIO引脚设为输入模式,等待DHT11响应,DHT11会先输出一个80us的低电平,然后输出一个80us的高电平,
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依