永发信息网

数据结构:设计一个算法将一个带头结点的单链表A分解成两个带头结点的单链表A和B

答案:2  悬赏:20  手机版
解决时间 2021-03-04 05:50
数据结构:设计一个算法将一个带头结点的单链表A分解成两个带头结点的单链表A和B
最佳答案
程序如下:
#include
#include
typedef struct node
{
char data;
struct node *nextPtr;
}*LinkList, Lnode;
static void CreateList(LinkList *headPtr, LinkList *tailPtr, char ch);
static void Decompose(LinkList *headPtrA, LinkList *headPtrB, LinkList *tailPtrB);
static void VisitList(LinkList headPtr);
static void DestroyList(LinkList *headPtr, LinkList *tailPtr);
int main(void)
{
LinkList headPtrA = NULL, tailPtrA = NULL, headPtrB = NULL, tailPtrB = NULL;
char ch;
while (1)
{
printf("Enter ch('@'-quit): ");
scanf(" %c", &ch);
if (ch == '@')
{
break;
}
else
{
CreateList(&headPtrA, &tailPtrA, ch);
}
}
VisitList(headPtrA);
if (headPtrA != NULL)
{
Decompose(&headPtrA, &headPtrB, &tailPtrB);
}
else
{

printf("headPtrA is empty.
");}
VisitList(headPtrA);
VisitList(headPtrB);
DestroyList(&headPtrA, &tailPtrA);
DestroyList(&headPtrB, &tailPtrB);
return 0;
}
static void CreateList(LinkList *headPtr, LinkList *tailPtr, char ch)
{
LinkList newPtr;
if ((newPtr = (LinkList)malloc(sizeof(Lnode))) == NULL)
{
exit(1);
}
newPtr -> data = ch;
newPtr -> nextPtr = NULL;
if (*headPtr == NULL)
{
newPtr -> nextPtr = *headPtr;
*headPtr = newPtr;
}
else
{
(*tailPtr) -> nextPtr = newPtr;
}
*tailPtr = newPtr;
}
static void Decompose(LinkList *headPtrA, LinkList *headPtrB, LinkList *tailPtrB)
{
int count = 0;
LinkList cA, pA;
char ch;
cA = NULL;
for (pA = *headPtrA; pA != NULL; cA = pA,pA = pA -> nextPtr)
{
ch = pA -> data;
count++;
if (count % 2 == 0)
{
CreateList(headPtrB, tailPtrB, ch);
cA -> nextPtr = pA -> nextPtr;
}
}
}
static void VisitList(LinkList headPtr)
{
while (headPtr != NULL)
{
printf("%c -> ", headPtr -> data);
headPtr = headPtr -> nextPtr;
}

printf("NULL
");}
static void DestroyList(LinkList *headPtr, LinkList *tailPtr)
{
LinkList tempPtr;
while (*headPtr != NULL)
{
tempPtr = *headPtr;
*headPtr = (*headPtr) -> nextPtr;
free(tempPtr);
}
*headPtr = NULL;
*tailPtr = NULL;
}
结构化查询语言(Structured Query Language)简称SQL(发音:/ˈes kjuː ˈel/ "S-Q-L"),是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统;同时也是数据库脚本文件的扩展名。
结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统, 可以使用相同的结构化查询语言作为数据输入与管理的接口。结构化查询语言语句可以嵌套,这使它具有极大的灵活性和强大的功能。
1986年10月,美国国家标准协会对SQL进行规范后,以此作为关系式数据库管理系统的标准语言(ANSI X3. 135-1986),1987年得到国际标准组织的支持下成为国际标准。不过各种通行的数据库系统在其实践过程中都对SQL规范作了某些编改和扩充。所以,实际上不同数据库系统之间的SQL不能完全相互通用。

全部回答
设第一个元素的序号为1,因此为奇数,若第一个元素的序号为0则A,B反过来赋值即可。
void SepList(ListNode *pSrc, ListNode **pLA, ListNode **pLB)
{
ListNode *pCur = pSrc;
ListNode *pA;
ListNode *pB;
*pLA = (ListNode*)malloc(sizeof(ListNode));
*pLB = (ListNode*)malloc(sizeof(ListNode));
pA = *pLA;
pB = *pLB;
while(pCur->next != NULL)
{
pA->next = pCur->next;
pCur->next = pCur->next->next;
pA = pA->next;
pA->next = NULL;
if (pCur->next != NULL)
{
pB->next = pCur->next;
pCur->next = pCur->next->next;
pB = pB->next;
pB->next = NULL;
}
}
free(pSrc);
}
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
女朋友是天蝎座的,我们异地恋,前段时间我去
英雄联盟怎么重装游戏
21岁和26岁适合在一起吗?会不会相差太多?
【说组词】什么的说组词
在哪可以看到车辆违章图片
可以恢复到刚买手机的时候的版本吗
为什么打Dota,真三,solo的永远比打3C的多?
文化路/洪河路(路口)在什么地方啊,我要过去
咽反射属于()
题目是a walk through the woods。后面的句子
在tcsec中有哪几个类别和哪几个等级
国家公务员,干部或事业单位还有土地确权吗
旺旺面包地址在哪,我要去那里办事
驾驶证扣分b照怎么处理查询
海信冰箱BCD-210TDU/X1-J怎么样
推荐资讯
怎样知道隐藏wifi和密码
新世纪家电怎么去啊,有知道地址的么
一鸣特沙发与爱佳至宝比哪个好?
糊涂了,40g之后不知道免不免流量
巴黎精致店地址有知道的么?有点事想过去
坡头宜佳五金店地址在什么地方,想过去办事
某科考队结束了两个月的海上考察,于4月21日
14新款奥迪A62.0T和2.5的哪款好
二分解算2一6
金银加工的,做这么一个黄金戒指大约得多少钱
雨滴下载的套装怎么安装
胶原蛋白缝合线是生物制品吗?
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?