POJ 3373 Changing Digits
题目大意:
给出一个数n,求m,使得m的长度和n相等。能被k整除。有多个数符合条件输出与n在每位数字上改变次数最小的。改变次数同样的输出大小最小的。
共同拥有两种解法:DP解法,记忆化搜索的算法。
以后会更新记忆化搜索。
1、DP解法:
解题思路:
DP[i][j]表示数n的前i位除以k余j最小改变几位。
DP[len][0]就表示数n被k整除最小改变几位。
依据这个关系从后向前遍历DP数组能够找出全部满足条件的数的路径。
再依据关系从前往后输出。
以下是代码:
#include <stdio.h>
#include <string.h>
int dp[110][10005];
bool vis[110][10005];
int mod;
int min(int a,int b)
{
if(a>b)a=b;
return a;
}
int main()
{
char s[105];
while(scanf("%s %d",s,&mod)!=EOF)
{
memset(dp,0x3f3f,sizeof(dp));
memset(vis,false,sizeof(vis));
int len=strlen(s);
/******特判部分↓*********/
if(mod==1)
{
puts(s);
continue;
}
if(len==1)
{
if((s[0]-'0')%mod==0)
{
puts(s);
}
else printf("%d\n",mod);
continue;
}
/****DP部分 ↓******/
for(int i=1; i<10; i++)
{
if(i==s[0]-'0')
{
dp[1][i%mod]=0;
}
else
{
dp[1][i%mod]=min(dp[1][i%mod],1);
}
}
for(int i=1; i<len; i++)
{
for(int j=0; j<mod; j++)
{
if(dp[i][j]!=dp[104][0])
{
for(int k=0; k<10; k++)
{
if(k==s[i]-'0')
{
if(dp[i+1][(j*10+k)%mod]>dp[i][j])
{
dp[i+1][(j*10+k)%mod]=dp[i][j];
}
}
else
{
if(dp[i+1][(j*10+k)%mod]>dp[i][j]+1)
{
dp[i+1][(j*10+k)%mod]=dp[i][j]+1;
}
}
}
}
}
}
/*****寻找路径部分 ↓******/
vis[len][0]=true;
for(int i=len-1; i>0; i--)
{
for(int j=0; j<mod; j++)
{
if(dp[i][j]!=dp[104][0])
{
for(int k=0; k<10; k++)
{
if(vis[i+1][(j*10+k)%mod]&&((dp[i][j]==dp[i+1][(j*10+k)%mod]&&k==s[i]-'0')||(k!=s[i]-'0'&&dp[i][j]+1==dp[i+1][(j*10+k)%mod])))
{
vis[i][j]=true;
break;
}
}
}
}
}
/*****输出部分 ↓*******/
int p=1,x=1;
for(; p<10; p++)
{
if(vis[1][p%mod])
{
printf("%d",p);
break;
}
}
while(x<len)
{
for(int k=0; k<10; k++)
{
if(vis[x+1][(p*10+k)%mod]&&((s[x]-'0'==k&&dp[x][p]==dp[x+1][(p*10+k)%mod])||(s[x]-'0'!=k&&dp[x][p]+1==dp[x+1][(p*10+k)%mod])))
{
printf("%d",k);
p=p*10+k;
p%=mod;
x++;
break;
}
}
}
puts("");
}
return 0;
}
POJ 3373 Changing Digits的更多相关文章
- poj 3373 Changing Digits (DFS + 记忆化剪枝+鸽巢原理思想)
http://poj.org/problem?id=3373 Changing Digits Time Limit: 3000MS Memory Limit: 65536K Total Submi ...
- POJ 3373 Changing Digits(DP)
题目链接 记录路径的DP,看的别人的思路.自己写的也不好,时间居然2000+,中间的取余可以打个表,优化一下. 写的各种错,导致wa很多次,写了一下午,自己构造数据,终于发现了最后一个bug. dp[ ...
- POJ 3373 Changing Digits 好蛋疼的DP
一開始写的高位往低位递推,发现这样有些时候保证不了第四条要求.于是又開始写高位往低位的记忆化搜索,又发现传參什么的蛋疼的要死.然后又发现高位開始的记忆化搜索就是从低位往高位的递推呀,遂过之. dp[i ...
- POJ 3373 Changing Digits 记忆化搜索
这道题我是看了别人的题解才做出来的.题意和题解分析见原文http://blog.csdn.net/lyy289065406/article/details/6698787 这里写一下自己对题目的理解. ...
- poj 2720 Last Digits
Last Digits Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 2233 Accepted: 474 Descri ...
- poj练习题的方法
poj1010--邮票问题 DFSpoj1011--Sticks dfs + 剪枝poj1020--拼蛋糕poj1054--The Troublesome Frogpoj1062--昂贵的聘礼poj1 ...
- poj很好很有层次感(转)
OJ上的一些水题(可用来练手和增加自信) (POJ 3299,POJ 2159,POJ 2739,POJ 1083,POJ 2262,POJ 1503,POJ 3006,POJ 2255,POJ 30 ...
- POJ题目分类推荐 (很好很有层次感)
著名题单,最初来源不详.直接来源:http://blog.csdn.net/a1dark/article/details/11714009 OJ上的一些水题(可用来练手和增加自信) (POJ 3299 ...
- sed武功心法(info sed翻译+注解)
本文中的提到GNU扩展时,表示该功能是GNU为sed提供的(即GNU版本的sed才有该功能),一般此时都会说明:如果要写具有可移植性的脚本,应尽量避免在脚本中使用该选项. 本文中的正则表达式几乎和gr ...
随机推荐
- autoprefixer小记
autoprefixer配置 // var aPostcss = [require('autoprefixer')({ browsers: ['ios>=3','android>=2',' ...
- CDOJ 1256 二维前缀和处理
昊昊喜欢运动 他NN 天内会参加MM 种运动(每种运动用一个[1,m][1,m] 的整数表示) 舍友有QQ 个问题 问昊昊第ll 天到第rr 天参加了多少种不同的运动 Input 输入两个数NN , ...
- sql 学习相关问题
---恢复内容开始--- 1.sql上面改变列的数据类型是 ALTER TABLE table_nameALTER COLUMN column_name datatype mysql上面是ALTER ...
- wooyun
转自:http://zone.wooyun.org/content/19128 tencent.com baidu.com sina.com.cn sohu.com discuz.net rising ...
- ALICTF2014 EvilAPK4脱壳分析
相关文件可以在下面链接中下载: http://pan.baidu.com/s/1sjpvFy9 1 简述 该apk使用libmobisec.so函数实现对dex的解密还原.真正的dex为assets目 ...
- photoshop 安装
Photoshop 下载: http://www.duote.com/soft/54352.html 下载完后解压选择..\Adobe CS6\Set-up.exe ,点击 Set-up.exe ...
- 【SQL Server】修改DB逻辑文件名称
步骤一:查询当前DB逻辑文件名称(主逻辑文件.日志逻辑文件) ; 步骤二:步骤二改变(还原)DB逻辑文件名称 RESTORE DATABASE AW831 FROM DISK='D:\AW831.DA ...
- [论文]A Link-Based Approach to the Cluster Ensemble Problem
论文作者:Natthakan Iam-On, Tossapon Boongoen, Simon Garrett, and Chris Price 下次还是在汇报前先写了论文总结,不然有些点汇报时容易忘 ...
- shell中规则表达式与特殊符号
在 bash 的操作环境中还有一个非常有用的功能,那就是通配符 (wildcard) ! 我们利用 bash 处理数据就更方便了!底下我们列出一些常用的通配符喔: 符号 意义 * 代表『 0 个到无穷 ...
- AC日记——食物链 codevs 1047
1074 食物链 2001年NOI全国竞赛 时间限制: 3 s 空间限制: 64000 KB 题目等级 : 钻石 Diamond 题解 题目描述 Description 动物王国中有 ...