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 ...
随机推荐
- sha1散列(C语言)
/** * \file sha1.h * * \brief SHA-1 cryptographic hash function * * Copyright (C) 2006-2010, Brainsp ...
- 11. KVC And KVO
1. KVC And KVO 的认识 KVC/KVO是观察者模式的一种实现 KVC全称是Key-value coding,翻译成键值编码.顾名思义,在某种程度上跟map的关系匪浅.它提供了一种使用 ...
- Centos7下安装mysql5.7.16
mysql的安装(root用户下) 从官网下载软件 linux下必须安装系统对应的版本,多少位 必须安装的是:server,client 但是我可不管要安装那个插件,我们直接使用bundle版本(就是 ...
- 土地购买(bzoj 1597)
Description 农夫John准备扩大他的农场,他正在考虑N (1 <= N <= 50,000) 块长方形的土地. 每块土地的长宽满足(1 <= 宽 <= 1,000, ...
- opencv2.4更换为opencv3.1后,mxnet编译错误(libpng16.so.16)
编译显示错误为: /usr/bin/ld: warning: libpng16.so.16, needed by /usr/local/lib/libopencv_imgcodecs.so, not ...
- 创建Azure DS 虚拟机并附加SSD硬盘
$subscriptionName = "Windows Azure Enterprise Trial" #订阅名称 $location = "China East&qu ...
- 用python读写excel(xlrd、xlwt)
最近需要从多个excel表里面用各种方式整理一些数据,虽然说原来用过java做这类事情,但是由于最近在学python,所以当然就决定用python尝试一下了.发现python果然简洁很多.这里简单记录 ...
- Service and controller in angularJs
Separation of concern is at the heart while designing an AngularJS application. Your controller must ...
- c#取得应用程序根目录
1.取得控制台应用程序的根目录方法 方法1.Environment.CurrentDirectory 取得或设置当前工作目录的完整限定路径方法2.AppDomain.CurrentDomain.Bas ...
- iOS UIColor RGB HEX
+(UIColor *)colorWithR:(CGFloat)r g:(CGFloat)g b:(CGFloat)b a:(CGFloat)a{ return [UIColor colorWithR ...