设计一个算法,把带表头结点的双向循环链表中的结点的数据域,按正负数据分成前负后正。

设计一个算法,把带表头结点的双向循环链表中的结点的数据域,按正负数据分成前负后正。基本思路我清楚,不用排序。请根据题目给出完整C算法。... 设计一个算法,把带表头结点的双向循环链表中的结点的数据域,按正负数据分成前负后正。
基本思路我清楚,不用排序。请根据题目给出完整C算法。
展开
 我来答
丨呜呼哀哉
2010-09-20 · TA获得超过285个赞
知道小有建树答主
回答量:145
采纳率:0%
帮助的人:179万
展开全部
很简单啊,2个指针,一个指向表头,一个指向表尾,双向搜索。表头指针发现正数,就stop;表尾指针发现负数就stop;然后2个指针交换指向的结构体;接着继续搜索,停止条件就是2个指针指向同一内容。时间效率O(n),空间效率1。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
匿名用户
2010-09-20
展开全部
typedef int data_type; /*双向链表结点数据域类型*/
typedef struct node{
data_type data;
struct node *next;
struct node *pre;
}node; /*双向链表数据结点数据结构*/

typedef struct dlist{
node *head;
unsigned int size;
} list; /*双向链表头结点数据结构*/

void fun(list *a) /*完成前负后正操作的函数*/
{
node *b,*e;
data_type tmp;
b=a->head;
e=a->head->pre;
while (b!=e)
{
if (b->data>=0||e->data<0) {
tmp=b->data;
b->data=e->data;
e->data=tmp;
}
b=b->next;
if (b==e) break;
e=e->pre ;
}
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友4ec6aac92
2010-09-20 · TA获得超过247个赞
知道答主
回答量:218
采纳率:100%
帮助的人:132万
展开全部
- - 不会还得排序吧 楼上正解
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式