poj2325
679 -> 378 -> 168 -> 48 -> 32 -> 6.(没有看懂啊)
就是说679的持久性是6,一位数持久性的结果是0,现在它是已知的有数字是11的持久性,目前尚且不知道什么是12的持久性,但是我们知道如果他们存在,那么位数至少会超过3000位。
这里需要你解决的问题是,什么是最小的数字这样计算的第一步,它的持久性结果在给定的数字?(好吧,看明白了,每一位数字之积,寻找等于这个数的最小的那个数字吧)没组测试数据输入一个不超过1000位的数字。
应该就是从最大的9开始除,一直除到1,如果最后的结果大于9那么就是不存在的了。算是贪心吧,毕竟是从最大的数字开始。可以看做是一耳光高精度运算,简单的除法。
试写代码吧。
算是1A吧,不过感觉代码写的好烂啊,不忍直视
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define maxn 1005
int OK, K, c[maxn];
int a[maxn];
void chu(int b[], int i, int n, int p)
{
int j, yu=0;
if(i==n && (b[i]==1||b[i]==0))return ;
if(p == 1)
{
OK = 0;
return ;
}
for(j=i; j<=n; j++)
c[j] = b[j];
for(j=i; j<=n; j++)
{
c[j] += yu * 10;
yu = c[j] % p;
c[j] /= p;
}
if(yu == 0)
{
a[K++] = p;
for(j=i; c[j] == 0 && j<=n; j++);
i=j;
for(; j<=n; j++)
b[j] = c[j];
chu(b, i, n, p);
}
else
chu(b, i, n, p-1);
}
int main()
{
char s[maxn];
while(scanf("%s", s), strcmp(s ,"-1"))
{
int i, n=strlen(s), b[maxn]={0};
for(i=0; i<n; i++)
b[i] = s[i] - '0';
OK = 1, K=0;
chu(b, 0, n-1, 9);
if(n==1)
printf("1%s\n", s);
else if(OK)
{
sort(a, a+K);
for(i=0; i<K; i++)
printf("%d", a[i]);
printf("\n");
}
else
printf("There is no such number.\n");
}
return 0;
}
poj2325的更多相关文章
- poj2325 大数除法+贪心
将输入的大数除以9 无法整除再除以 8,7,6,..2,如果可以整除就将除数记录,将商作为除数继续除9,8,...,3,2. 最后如果商为1 证明可以除尽 将被除过的数从小到大输出即可 #includ ...
- OJ题目分类
POJ题目分类 | POJ题目分类 | HDU题目分类 | ZOJ题目分类 | SOJ题目分类 | HOJ题目分类 | FOJ题目分类 | 模拟题: POJ1006 POJ1008 POJ1013 P ...
随机推荐
- 利用ASP.NET AJAX的Timer讓GridView每隔一段時間做到自動換頁的功能
最近在討論區看到這個問題,小弟利用asp.net ajax的timer來實作這個功能 利用timer每隔一段時間,讓gridview自動跳頁並且更新gridview的內容 asp.net(c#) Gr ...
- 【原】ios tableViewCell 自适应高度
原文:http://www.cnblogs.com/A--G/p/4819051.html 前言:之前在做一个类似微博的小需求时候,用table view实现了微博文字和图片等等的基本展示,由于文字和 ...
- sql uniqueidentifier转varchar
--- DECLARE @myid uniqueidentifierSET @myid = NEWID()SELECT CONVERT(char(255), @myid) AS 'char';GO-- ...
- ajax 操作全局监测,用户session失效
jQuery(function ($) { // 备份jquery的ajax方法 var _ajax = $.ajax; // 重写ajax方法,先判断登录在执行success函数 $.ajax = ...
- 数据挖掘经典书籍[ZZ]
数据挖掘就是在数据库中查找所需数据的过程,它是随着数据库产生的一门学科.近几年,数据库的发展还是非常迅速的,数据挖掘也成为热门技术,学习的人络绎不绝.下面给大家介绍的就是数据挖掘经典书籍及数据挖掘书籍 ...
- 服务器上搭建spark开发环境
1.安装相应的软件 (1)安装jdk 下载地址:http://www.Oracle.com/technetwork/java/javase/downloads/index.html (2)安装scal ...
- jQuery慢慢啃之选择器(二)
1.$("#myDiv");ID匹配一个元素 <span id="foo[bar]"></span> $("#foo\\[ba ...
- 检测js代码是否已加载的判断代码
该方法不局限于jQuery的检测,对与任何Javascript变量或函数都是通用的. 当前网页加载jQuery后,jQuery()或$()函数将会被定义,所以检测jQuery是否已经加载存在以下2种方 ...
- jQuery网页加载进度条插件
jquery.pace.js会自动监测你的Ajax请求,事件循环滞后,记录您的页面上准备状态和元素来决定的进度情况. 将pace.js和主题css的添加到您的网页! pace.js会自动监测你的Aja ...
- github的访问变慢了
以下个人观点:把操作系统的自主研究还有处理器自主研究列入重点,还有互联网上的种种动作,我发现里面似乎揭示了某些迹象,科研真的不应该以牺牲大部分人的河法全益为代价甚至目的.当某一天win不可能出现在出厂 ...