001 ///////////////////////////////////////////////////////////////////////////////
002 // Copyright (c) 2006, Frank S. Nestel, All Rights Reserved.
003 //
004 // This library is free software; you can redistribute it and/or
005 // modify it under the terms of the GNU Lesser General Public
006 // License as published by the Free Software Foundation; either
007 // version 2.1 of the License, or (at your option) any later version.
008 //
009 // This library is distributed in the hope that it will be useful,
010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
012 // GNU General Public License for more details.
013 //
014 // You should have received a copy of the GNU Lesser General Public
015 // License along with this program; if not, write to the Free Software
016 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
017 ///////////////////////////////////////////////////////////////////////////////
018
019 package de.spieleck.app.turn.splitting;
020
021 /**
022 * A SplittingMode for Zoff im Zoo aka Frank's Zoo.
023 * <br/>
024 * Playable with 4, 5 or 6 players. 5 Players is optimal.
025 *
026 * <p><a href="$URL: https://svn.sourceforge.net/svnroot/jtourney/src/de/spieleck/app/turn/splitting/Zoff.java $">$URL: https://svn.sourceforge.net/svnroot/jtourney/src/de/spieleck/app/turn/splitting/Zoff.java $</a></p>
027 *
028 * @author Frank S. Nestel
029 * @author $Author: nestefan $
030 * @version $Revision: 2 $ $Date: 2006-03-20 14:33:27 +0100 (Mo, 20 Mrz 2006) $ $Author: nestefan $
031 */
032 public class Zoff
033 extends BaseSplitter
034 {
035 public int optimal()
036 {
037 return 5;
038 }
039
040 public int[] split(int total)
041 {
042 if ( total < 4 || total == 7 )
043 {
044 return null; // Give up!
045 }
046 else
047 {
048 int x4 = total % 5;
049 int x6 = 0;
050 if ( x4 == 1 ) // Avoid 4 tables of 4 use one with 6!
051 {
052 x4 = 0;
053 x6 = 1;
054 }
055 else if ( x4 != 0 )
056 {
057 x4 = 5 - x4;
058 }
059 int x5 = (total - 4 * x4 - 6 * x6) / 5;
060 return new int[] { 0,0,0,0, x4,x5,x6 };
061 }
062 }
063 }