hoj 1014 Niven Numbers
新手上路之我的水题之路
刚开始时,我首先想到的是定义一个int数组,然后让输入的数字从最低位开始在循环不断地*base,从而将
k进制转化成十进制;然后再作取模判断就可以了;
这时在将最低位到最高位依次乘以相应的n次幂是,需要知道读入数字的位数:
while(t>)
{
n++; //n是最后得到的数字位数;
t=t/; //t是输入的数字;
}
然后得到了k进制转化成十进制的简单代码:
int main() {
int i,j,a,b,c,t,sum=,n=;
scanf("%d %d",&c,&b);
t=c;
while(t>)
{
n++;
t=t/;
}
t=c;
for(i=; i<=n; i++)
{
a=t%;
t=t/;
for(j=; j<i; j++)
{
sum+=a*b;
}
}
sum+=c%;
printf("%d\n",sum);
return ;
}
但是用这样的想法得到的代码一直是WA;
后来,经过一阵刻骨铭心的检查,发现应该使用字符串来读入数字;
这就有一个问题:
数字字符如何转化为数字来进行四则运算?
经过dalao的帮助,找到了s [ i ] - ' 0 ';来实现转化;
可是,用字符串改了之后一样不过!!!!!!!!
然后,又是在dalao的帮助下告诉我由于
未告知数据范围,默认为1e6!!!!
那么在a*b的时候就有可能爆炸!!!
没办法,改算法(@﹏@)~
在大佬的提示下,自己写了个除法竖式体会了一下:
最初的算法是从最低位开始乘幂,但实际上从最高位开始会更简单;
定义int x=0;
x=x*base+每次的最高位是s [ i ];
再令 x=x%sum //sum是每位上数字之和;
原理就在于:
1234%6==34%6;
从最高位开始,将可以舍去的位数数字全部舍去,这样就避免了数字过大的问题
一下是好不容易AC的代码C(89)
char s[];
int main()
{
int b,n,i,j,q,t;
while(scanf("%d",&b)==&&b!=)
{
scanf("%s",s);
n=strlen(s);
q=;
t=;
for(i=; i<n; i++)
{
q+=s[i]-'';
}
for(i=; i<n; i++)
{
t=t*b+(s[i]-'');
t=t%q;
} if(t%q==)
{
printf("yes\n");
}
else
{
printf("no\n");
}
}
return ;
}
hoj 1014 Niven Numbers的更多相关文章
- HOJ 1444 Humble Numbers
Humble Numbers My Tags (Edit) Source : University of Ulm Internal Contest 1996 Time limit : 1 sec Me ...
- HOJ题目分类
各种杂题,水题,模拟,包括简单数论. 1001 A+B 1002 A+B+C 1009 Fat Cat 1010 The Angle 1011 Unix ls 1012 Decoding Task 1 ...
- JS练习题-Harshad numbers
在Codewars上面练习,现在到6级的题目了(数字越小越难) 这道题叫Harshad or Niven numbers, 原题http://www.codewars.com/kata/54a0689 ...
- POJ题目细究
acm之pku题目分类 对ACM有兴趣的同学们可以看看 DP: 1011 NTA 简单题 1013 Great Equipment 简单题 102 ...
- 【转】POJ百道水题列表
以下是poj百道水题,新手可以考虑从这里刷起 搜索1002 Fire Net1004 Anagrams by Stack1005 Jugs1008 Gnome Tetravex1091 Knight ...
- 数位DP问题整理(一)
第一题:Amount of degrees (ural 1057) 题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1057 题意:[x,y ...
- HOJ1014
Niven Numbers My Tags (Edit) Source : Unknown Time limit : 1 sec Memory limit : 32 M Submitt ...
- HDU 1014 Uniform Generator【GCD,水】
Uniform Generator Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...
- HDU 1014 Uniform Generator(模拟和公式)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1014 Uniform Generator Time Limit: 2000/1000 MS (Java ...
随机推荐
- 在WebPart中获取Office 365中的未读邮件数
// Create the web request HttpWebRequest request = WebRequest.Create("https://outlook.office365 ...
- php_zip 类
<?php /** * Created by PhpStorm. * User: StarZhan * Date: 2016/5/24 * Time: 12:04 */class PHPZip{ ...
- 接触PHP快4个月
就要下班了,接触php快4个月,掌握的不好,需要实战,看到自己博客空空的,就mark一下吧!下班了...
- 你不知道的Spring配置文件
Spring配置文件是用于指导Spring工厂进行Bean生产.依赖关系注入(装配)及Bean实例分发的"图纸".Java EE程序员必须学会并灵活应用这份"图纸&quo ...
- APP里如何添加本地文本
首先考虑到用webview加载,那么久需要把文本转化成html的形势啊:如下,先把文字放到一个文本里,然后 文本转换H5: 1.在word中将文件格式布局 2.word中文本标题设为宋体标题,设字号, ...
- UIAlertController使用
// 将UIAlertController模态出来 相当于UIAlertView show 的方法// 初始化一个一个UIAlertController // 参数preferredStyle: ...
- unity的固定管线shader
最近shader学习中,看的视频. 练习的固定管线的shader如下: ps.在unity5中半透明不好用,其他的还好 //不区分大小写 //这是固定管线的Shader Shader "Sh ...
- CentOS Linux服务器安全设置
转自:http://www.osyunwei.com/archives/754.html 引言: 我们必须明白:最小的权限+最少的服务=最大的安全 所以,无论是配置任何服务器,我们都必须把不用的服务关 ...
- 五分钟搭建起一个包含CRUD功能的JqGrid表格
之前的项目也曾用过JgGrid对它的基本功能也是略有了解,网上有个国外的开源的项目,但是不适合个人的风格,所以花了3天空余的时间封装了下JqGrid,也算是参加开发工作10个月以来写的第一个比较完整的 ...
- [译]:Xamarin.Android开发入门——Hello,Android快速上手
返回索引目录 原文链接:Hello, Android_Quickstart. 译文链接:Xamarin.Android开发入门--Hello,Android快速上手 本部分介绍利用Xamarin开发A ...