/*
cout << " *****************game by ring light**************************" << endl;
cout << " **** 一個(gè)全開的循環(huán)串聯(lián)燈鏈 為節(jié)約資源等待你的關(guān)燈動(dòng)作******" << endl;
cout << " *****提示: 當(dāng)選擇一盞燈時(shí),該燈及旁邊的燈狀態(tài)均會(huì)發(fā)生變化****" << endl;
cout << " *****************game by ring light**************************" << endl;
破解辦法居然簡(jiǎn)單在于逐一從第一個(gè)點(diǎn)開關(guān)所有的燈就能實(shí)現(xiàn)所有的燈從全亮到全滅
*/
#include
using namespace std;
struct node
{
int data;
node *prev;
node *next;
public:
node():data(1),prev(NULL),next(NULL){}
node(int a):data(a),prev(NULL),next(NULL){}
};
void creat(node *list)
{
int n=20;
node *tmp;node *tail;
while(n--)
{
if(list->next == NULL)
{
tmp = new node(1);
tmp->prev = list;
tmp->next = list;
list->prev = tmp;
list->next = tmp;
tail=tmp;
}
else
{
tmp = new node(1);
list->next->prev = tmp;
tmp->next = list->next;
tmp->prev = tail;
tail->next=tmp;
list->next = tmp;
}
}
}
void show(node *list)
{
int n=20;
node *p = list->next;
while(n--)
{
//cout<<"["<<20-n<<"] "<data<<" ";
cout<data<<" ";
p=p->next;
}
cout<next;
while(x-- -1)
{
p=p->next;
}
p->prev->data=1-p->prev->data;
p->data=1-p->data;
p->next->data=1-p->next->data;
}
int check(node *list)
{
int n=20;
node *p = list->next;
while(n--)
{
if(p->data==1)break;
p=p->next;
}
return 1-p->data;
}
void play(node *list)
{
int x=1;
int n=40;
while(n--)
{
cout<<"40步解燈謎之"<<40-n<<"步:(輸入0~20)"<>x;
_play(list,x);
show(list);
if(n==20&&check(list))break;
}
}
int main()
{
cout << " *****************game by ring light**************************" << endl;
cout << " **** 一個(gè)全開的循環(huán)串聯(lián)燈鏈 為節(jié)約資源等待你的關(guān)燈動(dòng)作******" << endl;
cout << " *****提示: 當(dāng)選擇一盞燈時(shí),該燈及旁邊的燈狀態(tài)均會(huì)發(fā)生變化****" << endl;
cout << " *****************game by ring light**************************" << endl;
node list;
creat(&list); show(&list);
play(&list);
show(&list);
cout << " wzzx" << endl;
return 0;
}
標(biāo)題名稱:小代碼鏈表實(shí)現(xiàn)關(guān)燈游戲2
文章源于:
http://weahome.cn/article/iipjgs.html