
设计一个算法,把带表头结点的双向循环链表中的结点的数据域,按正负数据分成前负后正。
设计一个算法,把带表头结点的双向循环链表中的结点的数据域,按正负数据分成前负后正。基本思路我清楚,不用排序。请根据题目给出完整C算法。...
设计一个算法,把带表头结点的双向循环链表中的结点的数据域,按正负数据分成前负后正。
基本思路我清楚,不用排序。请根据题目给出完整C算法。 展开
基本思路我清楚,不用排序。请根据题目给出完整C算法。 展开
3个回答
展开全部
很简单啊,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 ;
}
}
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 ;
}
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
- - 不会还得排序吧 楼上正解
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |