reverser.java

来自「Java版的SAT求解器」· Java 代码 · 共 35 行

JAVA
35
字号
package positronic.satisfiability.bitstringrelation.binary;

import positronic.satisfiability.bitstring.BitStringEqualizer;
import positronic.satisfiability.elements.Conjunction;
import positronic.satisfiability.elements.Disjunction;
import positronic.satisfiability.elements.IProblem;
import positronic.satisfiability.elements.Problem;
import positronic.satisfiability.exceptions.ReverserException;

public class Reverser extends Problem implements IProblem
{
	private static final long serialVersionUID = 1L;

	public Reverser(BitStringBinaryRelation source,BitStringBinaryRelation ecruos) throws Exception
	{
		if(source==null || ecruos==null)
			throw new ReverserException("Null parameters were passed to the constructor.");
		if(source.getSize()!=ecruos.getSize())
			throw new ReverserException("BitStringBinaryRelations of different sizes were passed to the constructor.");
		IProblem accum2=null;
		for(int i=0;i<source.getSize();i++)
			for(int j=0;j<source.getSize();j++)
			{
				IProblem result1=new BitStringEqualizer(source.getBitString(i,0),ecruos.getBitString(i,1));
				IProblem result2=new BitStringEqualizer(source.getBitString(i,1),ecruos.getBitString(i,0));
				IProblem accum=new Conjunction(result1,result2);
				if(accum2==null)
					accum2=accum;
				else
					accum2=new Disjunction(accum2,accum);
			}
		this.setClauses(accum2.getClauses());
	}
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?