codeforces 2B The least round way(DP+数学)
The least round way
题目链接:http://codeforces.com/contest/2/problem/B
——每天在线,欢迎留言谈论。PS.本题有什么想法、建议、疑问 欢迎留言!!
题目大意:

①第一行给你一个n,表示接下来将给你一个n阶方阵的数据
②要求你从左上方出发到右下方,路径上所有数字乘积 的末尾0的个数最少
③输出最少0的个数,并输出路径
PS:①每次只能向右或向走 ②D表示向下走,R表示向右 ③0乘任何数的结果 末尾都是一个0;
知识点:
①多个数字相乘,末尾0个个数为:每个乘数分解质因数后 min(2的个数,5的个数);

②基本的DP(动态规划)- 本题dp出2、5 个数的最小值。
思路:
①末尾0个个数只跟线路上2、5的个数有关,所以读入数据时只要保存 2、5的个数即可

②通过dp,分别找出 2个数最小的路和5个数最小的路。
③那么结果有情况:下面用num2、num5表示 2、5最小的个数
④由于0比较特殊 所以需要考虑 (①把他当作10②记入第一个0的位子)(自己想为什么可以喽。。哈哈)
Ⅰ. num2、num5 当中全为0或其中一个为0
代表有某条路乘级末尾无0;直接输出。
Ⅱ . 如果输入数据中有0,那么0乘任何数末尾都是一个0,直接输出带0的一条路即可
Ⅲ . 其他无0情况 输出 min(num2,num5) 那条路就可以了!
感想:
这题的难点在于 对多个数相乘末尾0的个数性质的了解 和 对有0的处理 。
o.o 这个题要考虑的细节确实有点多,需要慢慢考虑。
o.o 输出的部分我既然写了40行代码。。。
PS.本题有什么想法、建议、疑问 欢迎留言!!
AC代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAXN=;
const int inf=0x3f3f3f3f;
struct node
{
int times[];
node(int a=,int b=){times[]=a;times[]=b;}
};
//----这里有几个全局变量↓
node matrix[MAXN][MAXN];int n;//记录每个点的质因子2 5的个数
bool isfind[MAXN][MAXN],ishavezero=false;//dp 时 记忆化搜索用
int zeroy=;
//----这里有几个全局变量↑
int get_num(int num,int y)
{//获取数字num 质因子中 y 的个数
int temp=;
while(num!=&&num%y==)
{
temp++;
num/=y;
}
return temp;
}
int dp(int y,int i=,int j=)//动态规划:通过记忆搜索的方法
{//y用来表示dp的是2还是5 y=0为2 y=1为5 ps.node结构体中int times[2];节省重复代码
if(isfind[i][j])//是否已搜索过
return matrix[i][j].times[y];
isfind[i][j]=true;
if(i==n&&j==n)//开始边界处理
{return matrix[i][j].times[y];}
else if(i==n)
return matrix[i][j].times[y]=matrix[i][j].times[y]+dp(y,i,j+);
else if(j==n)
return matrix[i][j].times[y]=matrix[i][j].times[y]+dp(y,i+,j);
//中间一般情况
return matrix[i][j].times[y]=matrix[i][j].times[y]+min(dp(y,i+,j),dp(y,i,j+));
}
void putout()
{//开始输出答案 ps.输出答案 写了40行的代码。。。。我也是lj
int y=;
if(matrix[][].times[]>matrix[][].times[])
y=;
if(ishavezero&&matrix[][].times[y]>)
{
cout<<""<<endl;
for(int i=;i<n;)
{
if(i==zeroy)
{
for(int j=;j<n;j++)
cout<<"D";
}
cout<<"R";i++;
}
return ;
}
cout<<matrix[][].times[y]<<endl;
for(int i=;i<=n;)
for(int j=;j<=n;)
{
if(j==n&&i==n)return ;
else if(j==n)
{for(int t=i;t<n;t++)
cout<<"D";return ;
}
else if(i==n)
{for(int t=j;t<n;t++)
cout<<"R";return ;
}
if(matrix[i+][j].times[y]<=matrix[i][j+].times[y])
{
cout<<"D";
i++;
}
else
{cout<<"R";j++;}
}
cout<<endl;
}
int main()
{
int temp;//接受输入的数
cin>>n;
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
{
cin>>temp;
if(!temp)
{temp=;if(!ishavezero){ishavezero=true;zeroy=j;}}
matrix[i][j]=node(get_num(temp,),get_num(temp,));
}
memset(isfind,,sizeof(isfind));//out();
dp();
memset(isfind,,sizeof(isfind));
dp();//out();
putout();
return ;
}
2017-05-12 13:21:50
codeforces 2B The least round way(DP+数学)的更多相关文章
- Codeforces #2B The least round way(DP)
Description 有一个n*n的正整数矩阵,要你求一条从第一行第一列的格子到第n行第n列的路,使得你走过的格子里面的数乘起来的值末尾的零的个数最小.输出最小个数. Input 第一行包括1个数n ...
- Codeforces 2B The least round way(dp求最小末尾0)
题目链接:http://codeforces.com/problemset/problem/2/B 题目大意: 给你一个nxn的矩形,找到一条从左上角到右下角的路径,使得该路径上所有数字的乘积的末尾0 ...
- codeforces 2B The least round way 【DP】
VJ上可找到中文题意. 思路: 首先分解有多少2与多少5.接下来就是dp. 分两次,一次是根据2的数量贪心,另外一次是根据5的数量贪心,看哪一次乘积的末尾0最少. 需要注意的是两点: 1.输入有0的情 ...
- Codeforces 2B. The least round way
There is a square matrix n × n, consisting of non-negative integer numbers. You should find such a w ...
- CodeForces 55D Beautiful numbers(数位dp+数学)
题目链接:http://codeforces.com/problemset/problem/55/D 题意:一个美丽数就是可以被它的每一位的数字整除的数. 给定一个区间,求美丽数的个数. 显然这是一道 ...
- codeforces 264 B. Good Sequences(dp+数学的一点思想)
题目链接:http://codeforces.com/problemset/problem/264/B 题意:给出一个严格递增的一串数字,求最长的相邻两个数的gcd不为1的序列长度 其实这题可以考虑一 ...
- 最小较小codeforces 2B The least round way
查了好多资料,发现还是不全,干脆自己整理吧,至少保证在我的做法正确的,以免误导读者,也是给自己做个记载吧! 求从左上角到右下角所经过的数字之积末端所含0最小的个数 终究的积可以当作A*2^x*5^y, ...
- CF 2B The least round way DP+Math
题意: 找出一条路, 使每个节点相乘,得到的数末尾 0 最少 每次移动只能向右或者向下, 找到后打印路径 ///按照题目要求,就是找出一条从左上角到右下角中每个数含2 or 5 最少的路 ///可以用 ...
- [CodeForces - 1225E]Rock Is Push 【dp】【前缀和】
[CodeForces - 1225E]Rock Is Push [dp][前缀和] 标签:题解 codeforces题解 dp 前缀和 题目描述 Time limit 2000 ms Memory ...
随机推荐
- 关于mysql的update、delete、和insert into能否使用别名问题
在工作中遇到这样一个问题,就是mysql在insert into时能不能使用别名,大家会很奇怪为什么insert into使用别名呢?原因在于原来的项目中使用了user表,新项目要将user表拆分为u ...
- Ocelot简易教程(四)之请求聚合以及服务发现
上篇文章给大家讲解了Ocelot的一些特性并对路由进行了详细的介绍,今天呢就大家一起来学习下Ocelot的请求聚合以及服务发现功能.希望能对大家有所帮助. 作者:依乐祝 原文地址:https://ww ...
- ionic 热更新 cordova-hot-code-push
cordova-hot-code-push ,Cordova热代码推送插件提供了在应用程序中执行基于Web的内容的自动更新的功能.使用此插件可以更新存储在项目的www文件夹中的所有内容. cordov ...
- Redis(2)---数据持久化
数据持久化 Redis有两种持久化的方式:快照(RDB文件)和追加式文件(AOF文件) (1)RDB持久化方式是在一个特定的间隔保存某个时间点的一个数据快照.(默认模式) (2)以日志的形式来记录每个 ...
- .Net 并发写入文件的多种方式
1.简介 本文主要演示日常开发中利用多线程写入文件存在的问题,以及解决方案,本文使用最常用的日志案例! 2.使用File.AppendAllText写入日志 这是种常规的做法,通过File定位到日志文 ...
- Linux编程 23 shell编程(结构化条件判断 命令if -then , if-then ... elif-then ...else,if test)
一.概述 在上一篇里讲到了shell脚本,shell按照命令在脚本中出现的顺序依次进行处理,对于顺序操作已经足够了,但许多程序要求对shell脚本中的命令加入一些逻辑流程控制,这样的命令通常叫做 结构 ...
- SpringBoot2.0应用(三):SpringBoot2.0整合RabbitMQ
如何整合RabbitMQ 1.添加spring-boot-starter-amqp <dependency> <groupId>org.springframework.boot ...
- Ansible常用模块介绍及使用(week5_day1_part2)--技术流ken
Ansible模块 在上一篇博客<Ansible基础认识及安装使用详解(一)--技术流ken>中以及简单的介绍了一下ansible的模块.ansible是基于模块工作的,所以我们必须掌握几 ...
- Python爬虫之多线程下载豆瓣Top250电影图片
爬虫项目介绍 本次爬虫项目将爬取豆瓣Top250电影的图片,其网址为:https://movie.douban.com/top250, 具体页面如下图所示: 本次爬虫项目将分别不使用多线程和使 ...
- [转]WEB页获取串口数据
本文转自:https://www.cnblogs.com/rockyhm/p/3434200.html 最近做一个B/S的项目,需要读取电子秤的值,之前一直没做过,也没有经验,于是在网上找到很多 大 ...