新手上路之我的水题之路

刚开始时,我首先想到的是定义一个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的更多相关文章

  1. HOJ 1444 Humble Numbers

    Humble Numbers My Tags (Edit) Source : University of Ulm Internal Contest 1996 Time limit : 1 sec Me ...

  2. HOJ题目分类

    各种杂题,水题,模拟,包括简单数论. 1001 A+B 1002 A+B+C 1009 Fat Cat 1010 The Angle 1011 Unix ls 1012 Decoding Task 1 ...

  3. JS练习题-Harshad numbers

    在Codewars上面练习,现在到6级的题目了(数字越小越难) 这道题叫Harshad or Niven numbers, 原题http://www.codewars.com/kata/54a0689 ...

  4. POJ题目细究

    acm之pku题目分类 对ACM有兴趣的同学们可以看看 DP:  1011   NTA                 简单题  1013   Great Equipment     简单题  102 ...

  5. 【转】POJ百道水题列表

    以下是poj百道水题,新手可以考虑从这里刷起 搜索1002 Fire Net1004 Anagrams by Stack1005 Jugs1008 Gnome Tetravex1091 Knight ...

  6. 数位DP问题整理(一)

    第一题:Amount of degrees (ural 1057) 题目链接:http://acm.timus.ru/problem.aspx?space=1&num=1057 题意:[x,y ...

  7. HOJ1014

    Niven Numbers My Tags   (Edit)   Source : Unknown   Time limit : 1 sec   Memory limit : 32 M Submitt ...

  8. HDU 1014 Uniform Generator【GCD,水】

    Uniform Generator Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  9. HDU 1014 Uniform Generator(模拟和公式)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1014 Uniform Generator Time Limit: 2000/1000 MS (Java ...

随机推荐

  1. 关于chart.js 设置canvas的宽度为父级元素的宽度的百分百 以及 X轴上面刻度数据太多如何处理

    今天在做一个数据统计的界面的时候,需要做折线统计图,在网上找了一圈发现数据统计的插件还是不少的,本着轻量级的的原则选择了Chart.js,后来在做的过程中便遇到两个问题,以此记录下来,和刚刚接触前端的 ...

  2. acm 1002 算法设计

    最近突然想往算法方向走走,做了做航电acm的几道题 二话不说,开始 航电acm 1002 题主要是处理长数据的问题,算法原理比较简单,就是用字符数组代替int,因为int太短需要处理的数据较长 下面是 ...

  3. mysql 创建用户、授权等操作

    一, 创建用户: 命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password'; 说明:username - 你将创建的用户名, host - 指 ...

  4. squid 2.7 通过域名反向代理多个服务器的配置方法

    详细配置及注释如下,供大家学习参考. visible_hostname squid1.abc.com #设定squid的主机名,如无此项squid将无法启动 http_port 80 accel vh ...

  5. css flex布局

    关于flex布局的一些简单用法 效果(下图) 实现代码: <!--html--> <div class="wrap"> <div class=&quo ...

  6. SimpleXML操控XML

    复杂字符串如下: $_xml=<<<_xml <?xml version="1.0" encoding="utf-8"?> < ...

  7. 了解一下OOP的反射API

    PHP5的类和对象函数并没有告诉我们类内部的所有一切,而只是报告了它们的公共成员.要充分了解一个类,需要知道其私有成员和保护成员,还要知道其方法所期望的参数 .对此,使用反射API. 1 查看自定义类 ...

  8. SecureCRT如何与Linux虚拟机进行关联

    首先在宿主机上确认虚拟网卡是否正确工作,并查看其IP地址,如本例中,宿主机的虚拟网卡VMnet8的IP地址为:192.168.121.1/24. VMnet8是VMware用于NAT连接的虚拟网卡. ...

  9. 使用Selector改变TextView的字体颜色textColor的方法

    先上Selector文件,名字为singer_fragment_top_text_style.xml, <?xml version="1.0" encoding=" ...

  10. java的布尔运算符和位运算符

    1.布尔运算符 &&  逻辑与: ||   逻辑或: !=  不等于: 三元操作符:?: :表达式为  condition?expression1:expression2(当条件为真时 ...