kouzdra (kouzdra) wrote,
kouzdra
kouzdra

Задача о ферзях:

t(a,b,c){int d=0,e=a&~b&~c,f=1;if(a)for(f=0;d=(e-=d)&-e;f+=t(a-d,(b+d)*2,(
c+d)/2));return f;}main(q){scanf("%d",&q);printf("%d\n",t(~(~0<<q),0,0));}

Работает, кстати

PS: алгоритм реально красивый - я этого варианта не знал - подробное разъяснение тут (откуда собственно это и вытащил) - начиная с последнего абзаца второй страницы
Subscribe

  • Post a new comment

    Error

    default userpic

    Your reply will be screened

    Your IP address will be recorded 

    When you submit the form an invisible reCAPTCHA check will be performed.
    You must follow the Privacy Policy and Google Terms of use.
  • 10 comments