【再度圖書館】

/*
  二叉樹小練習  子數組  8皇后92種狀況  
*/
#include<bits/stdc++.h>
using namespace std;
 #include <iostream>
using namespace std;
 typedef struct node
{
    int x;
    node*lc;
    node*rc;
    node(){} 
    node(int xx){x=xx;lc=NULL;rc=NULL;}
}*BiTree; 
int ss[]={4,2,1,0,0,3,0,0,6,5,0,0,7,0,0};int si=0; 
 
  
void Creat(BiTree &T)
{ 
 int d=ss[si++];
    if(d==0) T=NULL;
    else{
        T=new node(d);   Creat(T->lc); Creat(T->rc);
    }
}
void print(node *root,int base)
{ 
if(root)
   {    print(root->rc,base+1);
         int x=base;while(x--)cout<<"*";cout<<root->x<<endl;
        print(root->lc,base+1);
    }
}
int sum=0;
bool flag=false;
void maxsum(node *root)
{
if(root==NULL)return;
if(root->lc){maxsum(root->lc);root->x += root->lc->x;}
if(root->rc){maxsum(root->rc);root->x += root->rc->x;}
if(flag)
  {if(root->x > sum )sum=root->x;}
else
  {sum=root->x;flag=true;}
}
  int  sonTree(node *Tb,node *T)
{
 if(Tb)
 {
 if(Tb==T)return 1;
 return  sonTree(Tb->lc,T)+sonTree(Tb->rc,T);
 }
 else
 return 0;
}

node*pre=NULL;
node*cur=NULL;
void BiTreeToLinklist(node* T)   
{
    if(T != NULL) // 雙向鏈表化
    {
        BiTreeToLinklist(T->lc);
        T->lc  = pre;
	if(pre != NULL)
            {
             pre->rc = T;
               
            }
	pre = T;
 	  
        BiTreeToLinklist(T->rc);
    }
}

int main()
{
cout<<"-------- test 1---------------"<<endl;
     BiTree T; Creat(T);  print(T,4);




















return 0;

cout<<"-------- test 2 Tb---------------"<<endl;
node* p=new node();
 
pre=p;
BiTreeToLinklist(T);

p = p->rc;
while(p != NULL)
{
    cout<<p->x<<" ";
    p = p->rc;
}
/*
node* p=pre;
BiTreeToLinklist(T);
while(pre->lc != NULL)
  pre = pre->lc;

while(pre != NULL)
{
    cout<<pre->x<<" ";
    pre = pre->rc;
}
*/
cout<<endl;









         //maxsum(T);
         //cout<<"sum = "<<sum<<endl;
         //print(T,4);

return 0;
}
  
#include<bits/stdc++.h>
using namespace std;

void Combination1(int *arr,int *brr,int n,int k)
{
	if(k == n)
	{
		for(int i=0;i < n;++i)
		{
			if(brr[i] == 1)
			{
				cout<<arr[i]<<" ";
			}
		}
		cout<<endl;
	}
	else
	{
		brr[k] = 1;  Combination1(arr,brr,n,k+1);
		brr[k] = 0;  Combination1(arr,brr,n,k+1);
	}
}

void Combination(int *arr,int *brr,int n,int k)
{ 
	while(k >= 0)
	{
		if(k == n)
		{
			for(int i=0;i < n;++i)
			{
				if(brr[i] == 1) cout<<arr[i]<<" ";				 
			}
			cout<<endl;
			 --k; 
			while(brr[k] == 0)  brr[--k] == 0;
 
		}
		else if(brr[k] == 0) brr[k++] = 1;		 
		else        brr[k++] = 0;
		 
	}
}


void Combination(int *arr,int n)
{
	if(arr == NULL) return ;
	int *brr = new int[n];
	memset(brr,0,sizeof(int)*n);
	Combination(arr,brr,n,0);
}

int main()
{
int arr[3]={1,2,3};
Combination(arr,3);
return 0;
}
#include<bits/stdc++.h>
#include<iostream>
using namespace std;
#include<cstring>


int abs(int n)
{
    return n<0?-n:n;
}

bool place(int* x,int k)
{
    for(int i=0;i < k;++i)
    { 
        if(x[i] == x[k] || abs(x[i]-x[k]) == k-i)
        {
             return false;
        }
    }
    return true;
}

void nQueue(int n,int *x,int k,int &sum)
{
    if(k == n)
    {
        for(int i=0;i < n;++i)
        {
            for(int j=0;j < n;++j)
            {
                if(x[i] == j)
                {
                    cout<<"Q";
                }
                cout<<"#";
            }
            cout<<endl;
        }
        cout<<endl;
        ++sum;
    }
    else
    {
        for(int i=0;i < n;++i)
        {
            x[k] = i;
            if(place(x,k))
            {
                nQueue(n,x,k+1,sum);
            }
        }
    }
}

int nQueue(int n)
{
    int sum = 0;
    int *x = new int[n];
    memset(x,0,sizeof(int)*n);
    nQueue(n,x,0,sum);
    return sum;
}

#define n  4
int a[n][n];
void array(int cc)
{
   for(int i=0;i<n;i++)
    {
      for(int j=0;j<n;j++)
        { 
           if(cc==0) a[i][j]=0;
           else cout<<a[i][j]<<" ";
         }
           if(cc!=0)cout<<endl;           
    }
}
struct point
{
int x,y;
point(){};
point(int xx,int yy){x=xx;y=yy;}
};
point d[n];
int gs=0;
int check(int i,int j)
{
  for(int k=0;k<n;k++)
  {
     if(gs==0)return 1;
     if(abs(i-d[k].x)==0||abs(j-d[k].y)==0) return 0;
     if(abs(i-d[k].x)==abs(j-d[k].y)||abs(i-d[k].x)==abs(j-d[k].y)) return 0;
     if(d[k].x==0&&d[k].y==0)  break;
  }
  a[i][j]=1;
  d[gs].x=i;d[gs].y=j;
}
void fun()
{
  for(int i=0;i<n;i++)
  {
    for(int j=0;j<n;j++)
       {
        if(check(i,j)){ d[gs].x=i;d[gs].y=j;gs++;}
       }
  }
}
int main()
{
array(0);
fun();
array(1);
    int xx;
//    cin>>xx;
    //cout<<nQueue(xx)<<endl;
    return 0;
}
相關文章
相關標籤/搜索