//灯塔问题
#include <iostream.h>
#include <fstream.h>
#include <conio.h>
int sz[11][11],cf=1,k,n,a[20],b[20],c[20];
void shuru(void);
void shuchu(void);
bool panduan(void);
void goujian(void);
void main()
{
int i,j,lj=0,d;
shuru();
for(i=1;i<=n;i++)cf=cf*2;
for(i=0;i<cf;i++)
{
d=i;
for(j=1;j<=n;j++)
{sz[n][n-j+1]=d%2;d=d/2;}
goujian();
if(panduan()==true){lj=lj+1;shuchu();}
}
cout<<”共有”<<lj<<”种情况”<<endl;
getch();
}
void goujian(void)
{
int i1,j1;
for(i1=n-1;i1>0;i1–)
{
for(j1=1;j1<=i1;j1++)
{
if(sz[i1+1][j1]==1&&sz[i1+1][j1]==1)
sz[i1][j1]=0;
if(sz[i1+1][j1]==0&&sz[i1+1][j1+1]==0)
sz[i1][j1]=0;
if(sz[i1+1][j1]==1&&sz[i1+1][j1+1]==0)
sz[i1][j1]=1;
if(sz[i1+1][j1]==0&&sz[i1+1][j1+1]==1)
sz[i1][j1]=1;
}
}
}
bool panduan()
{
int pd=1,j1;
for(j1=1;j1<=k;j1++)
if(sz[a[j1]][b[j1]]!=c[j1]) pd=0;
if(pd==0) return false;else return true;
}
void shuchu(void)
{
int i2,j2;
for(i2=1;i2<=n;i2++)
{
for(j2=1;j2<=n-i2;j2++) cout<<” “;
for(j2=1;j2<=i2;j2++) cout<<sz[i2][j2]<<” “;
cout<<endl;
}
cout<<endl;
}
void shuru(void)
{
// char filename[18];
ifstream input;
// cout<<”Input filename:”;
// cin>>filename;
// input.open(filename);
input.open(“dt.txt”);
input>>n;
k=0;
do{
k++;
input>>a[k]>>b[k]>>c[k];
}while((a[k]!=0)&&(b[k]!=0));
k–;
}
-
近期文章
近期评论
- coolker 发表在《打造最快的Hash表》
- struggle 发表在《提供C语言教学课件(适用于初学者)》
- zhanghaibo 发表在《提供C语言教学课件(适用于初学者)》
- zhanghaibo 发表在《提供C语言教学课件(适用于初学者)》
- diys 发表在《C语言编程宝典(王大刚) 1.1 C 语言的产生与发展》
文章归档
- 2022 年十月
- 2014 年一月
- 2013 年十二月
- 2012 年十一月
- 2012 年七月
- 2012 年六月
- 2012 年五月
- 2012 年四月
- 2012 年三月
- 2012 年二月
- 2011 年十二月
- 2011 年十月
- 2011 年九月
- 2011 年八月
- 2011 年七月
- 2011 年六月
- 2011 年五月
- 2011 年四月
- 2011 年三月
- 2011 年二月
- 2011 年一月
- 2010 年十二月
- 2010 年十一月
- 2010 年十月
- 2010 年九月
- 2010 年八月
- 2010 年七月
- 2010 年六月
- 2010 年五月
- 2010 年四月
- 2010 年三月
- 2010 年二月
- 2010 年一月
- 2009 年十二月
- 2009 年十一月
- 2009 年十月
- 2009 年九月
- 2009 年八月
- 2009 年七月
- 2009 年六月
- 2009 年五月
- 2009 年四月
- 2009 年三月
- 2009 年二月
- 2009 年一月
- 2008 年十二月
- 2008 年十一月
- 2008 年十月
- 2008 年九月
- 2008 年八月
- 2008 年七月
- 2008 年六月
- 2008 年五月
- 2008 年四月
- 2008 年三月
- 2008 年二月
- 2008 年一月
- 2007 年十二月
- 2007 年十一月
- 2007 年十月
- 2007 年九月
- 2007 年八月
- 2007 年七月
- 2007 年六月
- 2007 年三月
- 2007 年二月
- 2007 年一月
- 2006 年十二月
- 2006 年十一月
- 2006 年十月
- 2006 年九月
- 2006 年八月
- 2006 年七月
- 2006 年六月
- 2006 年五月
- 2006 年四月
- 2006 年三月
- 2006 年二月
- 2006 年一月
- 2005 年十二月
- 2005 年十一月
分类目录
功能