24点游戏动态规划解法(java)

本文介绍了24点游戏的动态规划解决方案,详细阐述了算法原理,并提供了Java实现代码,通过子问题S[i] U= Fork(f(x),f(i-x))来求解。" 122313377,7335873,PMBOK第六版中文详解,"['项目管理', 'PMBOK指南', '管理框架']
摘要由CSDN通过智能技术生成


算法原理参考编程之美1.16章节解法2:

下面是java源码:子问题为S[i] U= Fork(f(x),f(i-x));


import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Scanner;
import java.util.Set;

class Elem{
	public double res;
	public String info;
	public Elem(double r,String i){
		res = r;
		info = i;
	}
}
public class CalculateAnswer {
	
	private final int N = 4;
	private final int res = 24;
	private int[] A;
	private Map<Integer, Set<Elem>> map;
	private Set<String> answers;
	
	public CalculateAnswer(int[] a) {
		A = a;
		map = new HashMap<Integer, Set<Elem>>();
		answers = new HashSet<String>();

	}
	public void run() {
		for(int i=0;i<(1<<N);i++) {
			Set<Elem> set = new HashSet<Elem>();
			map.put(i,set);
		}
		for(int i=0;i<N;i++){
			Elem e = new Elem(A[i], A[i]+"");
			Set&l
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值