回 帖 发 新 帖 刷新版面

主题:跪求!!单链表倒置&&QQ群

单链表倒置不用栈,就用单链表怎么做啊
还有八皇后怎么做....
谢谢!!
QQ群:50076170

回复列表 (共10个回复)

沙发

viod fanzhuanlist(ptsqlist list)
{    elementtype mid;
    int a,z;
    a=0;z=list->n-1;
    for (;a<z;a++,z--)      /*逆转顺序表*/
    {
        mid=list->element[a];
        list->element[a]=list->element[z];
        list->element[z]=mid;
    }
}

板凳

带表头:
void reversel(linklist *&L)
{
linklis *p=L->next,*q;
while(p!=NULL)
{
q=p->next;
p->next=L->next;//用头插法
L->next=p;
p=q;
}
}

3 楼

不带头节点:
先将首节点的next置为NULL,用p,q两指针指向单链表中相邻的两节点,将r指向*q的下一个节点,然后同步后移。当q=NULL时,表示P指向原单链表的尾节点,将L的next指向*p节点即可。
void reverse(link *&l)
{
linklist *P=l->next,*q,*r;
if(p!=NULL)
{
q=p->next;
while(q!=NULL)
{
r=q->next;
q->next=p;
p=q;
q=r;
}
L->next=p;
}
}

4 楼

当然单链表逆转还有好多方法
八皇后问题到处都有,怎么样的代码都有


在一个8×8国际象棋盘上,有8个皇后,每个皇后占一格;要求皇后间不会出现相互“攻击”的现象,即不能有两个皇后处在同一行、同一列或同一对角线上。问共有多少种不同的方法。

*问题分析与算法设计
这是一个古老的具有代表性的问题,用计算机求解时的算法也很多,这里仅介绍一种。
采用一维数组来进行处理。数组的下标i表示棋盘上的第i列,a[i]的值表示皇后在第i列所放的位置。如:a[1]=5,表示在棋盘的第一例的第五行放一个皇后。
程序中首先假定a[1]=1,表示第一个皇后放在棋盘的第一列的第一行的位置上,然后试探第二列中皇后可能的位置,找到合适的位置后,再处理后续的各列,这样通过各列的反复试探,可以最终找出皇后的全部摆放方法。
程序采用回溯法,算法的细节参看程序。

*程序说明与注释
#include<stdio.h>
#define NUM 8 /*定义数组的大小*/
int a[NUM+1];
int main()
{
int i,k,flag,not_finish=1,count=0;
i=1; /*正在处理的元素下标,表示前i-1个元素已符合要求,正在处理第i个元素*/
a[1]=1; /*为数组的第一个元素赋初值*/
printf("The possible configuration of 8 queens are:\n");
while(not_finish) /*not_finish=1:处理尚未结束*/
{
while(not_finish&&i<=NUM) /*处理尚未结束且还没处理到第NUM个元素*/
{
for(flag=1,k=1;flag&&k<i;k++) /*判断是否有多个皇后在同一行*/
if(a[k]==a[i])flag=0;
for(k=1;flag&&k<i;k++) /*判断是否有多个皇后在同一对角线*/
if((a[i]==a[k]-(k-i))||(a[i]==a[k]+(k-i))) flag=0;
if(!flag) /*若存在矛盾不满足要求,需要重新设置第i个元素*/
{
if(a[i]==a[i-1]) /*若a[i]的值已经经过一圈追上a[i-1]的值*/
{
i--; /*退回一步,重新试探处理前一个元素*/
if(i>1&&a[i]==NUM)
a[i]=1; /*当a[i]为NUM时将a[i]的值置1*/
else if(i==1&&a[i]==NUM)
not_finish=0; /*当第一位的值达到NUM时结束*/
else a[i]++; /*将a[i]的值取下一个值*/
}
else if(a[i]==NUM) a[i]=1;
else a[i]++; /*将a[i]的值取下一个值*/
}
else if(++i<=NUM)
if(a[i-1]==NUM) a[i]=1; /*若前一个元素的值为NUM则a[i]=1*/
else a[i]=a[i-1]+1; /*否则元素的值为前一个元素的下一个值*/
}
if(not_finish)
{
++count;
printf((count-1)%3?" [%2d]: ":" \n[%2d]: ",count);
for(k=1;k<=NUM;k++) /*输出结果*/
printf(" %d",a[k]);
if(a[NUM-1]<NUM) a[NUM-1]++; /*修改倒数第二位的值*/
else a[NUM-1]=1;
i=NUM-1; /*开始寻找下一个足条件的解*/
}
}
}

*思考题
一个8×8的国际象棋盘,共有64个格子。最多将五个皇后放入棋盘中,就可以控制整个的盘面,不论对方的棋子放哪一格中都会被吃掉。请编程找出这样的五个“皇后”可能的布局

5 楼

大哥,死循环啦!!!

6 楼


呵呵。傻孩子,我要的是单链表!!
不是顺序表。。。。。

7 楼

[quote]
呵呵。傻孩子,我要的是单链表!!
不是顺序表。。。。。[/quote]
我写的就是单链表!

8 楼


oh.我的错,看错人啦
上面有一个是顺序表
你的那个带头节点的单链表导致死循环啦
呵呵[em9]

9 楼

兄弟是新手啊 ,大家 多照着点....
typedef int datatype
typedef struct node 
 {datatype num;
  struct node * next
 }list;
  list *   convert          (list *head,p,q;)
{p=head->next;q=p->next;
  head->next=null; 
  if (q)
   {head->next=q;
    head->next->next=p;
    p=q;q=q->next;
    }
  return (head);
}

10 楼

强烈支持用头插法

我来回复

您尚未登录,请登录后再回复。点此登录或注册