BNU 25593 Prime Time 记忆化dp
题目链接:点击打开链接
题意:
一个游戏由3个人轮流玩
每局游戏由当中一名玩家选择一个数字作为開始
目的:获得最小的得分
对于当前玩家 O 。面对 u 这个数字
则他的操作有:
1、 计分 u +1 ,然后 u++;
2、计分 u / x, 然后 u /= x; 当中x为u的因子且x为素数
然后下一个玩家继续上述操作
3个人各操作一次 为1轮
当一轮结束后,若u==1 则游戏结束
每一个人的得分为 他全部计分记录里最小的数字
若在一轮结束前 u就==1, 那么玩家的得分为本局游戏的初始数
求:
每一个人在採取最优操作下玩n局游戏的总得分(不同局得分相加)
输入n表示n局游戏
以下n行给定 人名缩写+u
表示哪个玩家開始,他选择了哪个数字
思路:
1、n局游戏之间各不影响,所以分开考虑每局游戏
2、对于一局游戏。则我们能够记忆化搜索出每一个数字u相应的状态
显然我们能够得到若u为素数时 答案就是 { 1, u, u}
若u不为素数,则u能够转移到状态v
在保证第一个数字最小的情况下,从越小的状态转移过来则结果越小
注意素数初始化时我们觉得是{prime, inf, inf} 这样会得到一些不存在状态,而不存在的状态意义是本局游戏的初值
#include <stdio.h>
#include <algorithm>
#include<iostream>
#include<string.h>
#include <math.h>
#include<queue>
#include<map>
#include<vector>
#include<set>
using namespace std;
#define N 100008
#define inf 100000000
#define ll int
ll prime[9599], primenum;
set<int>s;
void PRIME(ll Max_Prime){
primenum = 0;
prime[primenum++] = 2;
for(ll i = 3; i <= Max_Prime; i+= 2)
for(ll j = 0; j < primenum; j++)
if(i%prime[j]==0)break;
else if(prime[j] > sqrt((double)i) || j==primenum-1)
{
prime[primenum++] = i;
break;
}
}
struct node{
int a,b,c,ok;
node(int x=0,int y=0,int z=0,int yes=0):a(x),b(y),c(z),ok(yes){}
}dp[N];
void dfs(int u){
if(dp[u].ok)return;
int t, fir = inf, id = inf;
for(int i = 0; prime[i] <= u; i++)if(u % prime[i]==0) {
dfs(u/prime[i]);
t = min(u/prime[i], dp[u/prime[i]].c);
if(t < fir || (t == fir && u/prime[i] < id))
fir = t, id = u/prime[i];
}
dfs(u+1);
t = min(u+1, dp[u+1].c);
if(t < fir || (t == fir && u+1 < id))
fir = t, id = u+1;
dp[u] = node( fir, dp[id].a, dp[id].b, true);
}
int main(){
int i, n;
PRIME(100007);
s.clear();
for(i = 0; i < N; i++) dp[i].ok = false;
for(i = 0; i < primenum; i++) {
dp[prime[i]] = node(1, inf, inf, true);
s.insert(prime[i]);
}
dp[1] = node(1, 1, 1, true);
while(~scanf("%d",&n)){
node ans = node(0, 0, 0, true);
while(n--){
char ch[2]; int u;
scanf("%s %d", ch, &u);
dfs(u);
node tmp = dp[u];
if(tmp.a == inf) tmp.a = u;
if(tmp.b == inf) tmp.b = u;
if(tmp.c == inf) tmp.c = u; if(ch[0] == 'O')
ans.a += tmp.a, ans.b += tmp.b, ans.c += tmp.c;
else if(ch[0] == 'E')
ans.b += tmp.a, ans.c += tmp.b, ans.a += tmp.c;
else
ans.c += tmp.a, ans.a += tmp.b, ans.b += tmp.c;
}
printf("%d %d %d\n", ans.a,ans.b, ans.c);
}
return 0;
}
BNU 25593 Prime Time 记忆化dp的更多相关文章
- Google Code Jam 2009, Round 1C C. Bribe the Prisoners (记忆化dp)
Problem In a kingdom there are prison cells (numbered 1 to P) built to form a straight line segment. ...
- UVA - 11324 The Largest Clique 强连通缩点+记忆化dp
题目要求一个最大的弱联通图. 首先对于原图进行强连通缩点,得到新图,这个新图呈链状,类似树结构. 对新图进行记忆化dp,求一条权值最长的链,每一个点的权值就是当前强连通分量点的个数. /* Tarja ...
- cf835(预处理 + 记忆化dp)
题目链接: http://codeforces.com/contest/835/problem/D 题意: 定义 k 度回文串为左半部分和右半部分为 k - 1 度的回文串 . 给出一个字符串 s, ...
- cf779D(记忆化dp)
题目链接: http://codeforces.com/problemset/problem/799/D 题意: 给出两个矩阵边长 a, b, 和 w, h, 以及一个 c 数组, 可选择 c 数组中 ...
- Codeforces1107E Vasya and Binary String 记忆化dp
Codeforces1107E 记忆化dp E. Vasya and Binary String Description: Vasya has a string \(s\) of length \(n ...
- POJ 1088 滑雪(简单的记忆化dp)
题目 又一道可以称之为dp的题目,虽然看了别人的代码,但是我的代码写的还是很挫,,,,,, //看了题解做的简单的记忆化dp #include<stdio.h> #include<a ...
- POJ 1088 滑雪 记忆化DP
滑雪 Time Limit: 1000MS Memory Limit: 65536K Description Michael喜欢滑雪百这并不奇怪, 因为滑雪的确很刺激.可是为了获得速度 ...
- [luogu]P1514 引水入城[搜索][记忆化][DP]
[luogu]P1514 引水入城 引水入城 题目描述在一个遥远的国度,一侧是风景秀美的湖泊,另一侧则是漫无边际的沙漠.该国的行政区划十分特殊,刚好构成一个N 行M 列的矩形 ,如下图所示,其中每个格 ...
- 记忆化dp博弈
题:http://poj.org/problem?id=2068 题意: 有两个队伍A,B,每个队伍有N个人,交叉坐.即是A(1,3,5,7.....)B(2,4,6,8....).告诉你每个mi(1 ...
随机推荐
- hystrix 解决服务雪崩效应
1.服务雪崩效应 默认情况下tomcat只有一个线程池去处理客户端发送的所有服务请求,这样的话在高并发情况下,如果客户端所有的请求堆积到同一个服务接口上, 就会产生tomcat的所有线程去处理该服务接 ...
- bind - 将一个名字和一个套接字绑定到一起
SYNOPSIS 概述 #include <sys/types.h> #include <sys/socket.h> int bind(int sockfd, struct s ...
- 修改phpadmin中的默认超时时间
登录后1440秒未活动后总是自动退出,一天还要登录多次,终于有时间来解决这个问题了,感觉是session超时,结果在网上search了下,找到解决办法啦,哈哈哈,在此做个笔记: phpmyadmin在 ...
- java将很长的一条sql语句,自动换行输出(修改版)2019-06-01(bug未修复)
package org.jimmy.autosearch2019.test; import java.util.HashMap; public class AutoLinefeedSql { publ ...
- Chrome插件:本地程序实现验证码破解(浏览器与本地进程通信)
利用chrome调用本地程序破解图片验证码background.js var port = null, tabId, fname = "vcode.chrome.v1.item.01&quo ...
- 笔试算法题(57):基于堆的优先级队列实现和性能分析(Priority Queue based on Heap)
议题:基于堆的优先级队列(最大堆实现) 分析: 堆有序(Heap-Ordered):每个节点的键值大于等于该节点的所有孩子节点中的键值(如果有的话),而堆数据结构的所有节点都按照完全有序二叉树 排.当 ...
- spring Boot 不认Mapper.xml
很久以前的笔记了,大约就是用Generatro工具自动生成代码的时候,springboot找不到mapper.xml 之前,由于用mybatis-generator自动生成了entity,dao,ma ...
- ceph集群
ceph集群部署 ceph理解: Ceph是一个分布式存储,可以提供对象存储.块存储和文件存储,其中对象存储和块存储可以很好地和各大云平台集成.其他具体介绍可见官网简介:http://docs.cep ...
- 源码学习-Object类
1.Object类是Java所有类的超类 2.查看Object的属性和方法,发现Object类没有属性,只有13个方法,其中7个本地方法. 3.接下来看具体的方法 3.1 Object() 默认的构造 ...
- PHP导出超大的CSV格式的Excel表方案
场景和痛点 说明 我们工作场景都常会导出相关的excel数据,有时候需要大量的数据,10W,100W都有可能 我们现有方案都是直接利用phpexcel等类库来操作,phpexcel的load加载或是写 ...