- 浏览: 602088 次
- 性别:
- 来自: 北京
文章分类
最新评论
1到11有4个“1”,1中一个“1”,10中一个“1”,11中两个“1”,1000中,有多少个“1”,欢迎给出你的解法!
wjason 写道jythoner 写道avanry 写道String.valueOf()和charAt()这两个方法用的好啊!但是上个方法在做下一道题的时候会有问题计算1-400亿有多少个1?很奇怪, 楼主既然想到了这个问题, 问什么还给出上面的答案呢.呵呵,因为简单的问题有简单的解法,如果是400亿的话,主要是靠找规律,然后计算。和1000这种小数字不同,虽然1000也可以使用找规律的算法,但如果是2343这种没规律的数字的话,难度会增加。
hand, hand.
想法完全一致 呵呵.
为了这个任意数字,
我还现找了一个数学系的同学讨论了一下.
我们得出了999...9的规律
当问及任意数字的时候.
他的建议是让我再找个搞组合数学的....
虽然时间不多...但是大数据就有优势了
原来我错了...INDEXOF这个计算比循环还多...
算了下..比楼主的要快一点..呵.
我把它转成数组int[] str:
public static int count(int[] str)
{
//初始化
int k = str.length;
//计数器
int count = 0;
//寻找到最右边的0
while(k >= 1 && str[k]==1)
{
count ++;
}
return count ;
}
jythoner 写道avanry 写道String.valueOf()和charAt()这两个方法用的好啊!但是上个方法在做下一道题的时候会有问题计算1-400亿有多少个1?很奇怪, 楼主既然想到了这个问题, 问什么还给出上面的答案呢.
呵呵,因为简单的问题有简单的解法,如果是400亿的话,主要是靠找规律,然后计算。和1000这种小数字不同,虽然1000也可以使用找规律的算法,但如果是2343这种没规律的数字的话,难度会增加。
avanry 写道String.valueOf()和charAt()这两个方法用的好啊!但是上个方法在做下一道题的时候会有问题计算1-400亿有多少个1?
很奇怪, 楼主既然想到了这个问题, 问什么还给出上面的答案呢.
我也思考了一下, 简单说一下思路
0的个数 | 范围
9 | 1 - 99
180 | 100 - 999
2700 | 1000 - 9999
36000 | 10000 - 99999
-------------------------------------
38889(合计结果)
接下来是488889
5888889
... 知道n
另:1到999999999999999999.....之间
1..9这九个数字的个数相同.
所以到400亿, 这个数字好求.
到任意数字,比如 56786435, 则要难一些.
这个需求有点复杂,
还没想好,
我得好好回忆一下我的数学知识.....
en pass...
String.valueOf()和charAt()这两个方法用的好啊!
但是上个方法在做下一道题的时候会有问题
计算1-400亿有多少个1?
package test07; public class CountOne { public static void main(String[] args) { int count = 0; for (int i = 1; i <= 1000; i++) { String s = String.valueOf(i); for (int j = 0; j < s.length(); j++) { if (s.charAt(j) == '1') count++; } } System.out.println(count); } }
评论
16 楼
ccjsjymg
2009-02-28
package util; public class CountOne { public static void main(String[] args) { int count = 0; for(int i = 1;i < 1001;i++){ String str = String.valueOf(i); String[] s = str.split(""); for(int j = 0;j < s.length;j++){ if(!"1".equals(s[j])){ continue; }else{ count++; } } } System.out.println("从1到1000中含有1的数字总数为:"+count); } }
15 楼
wjason
2009-02-06
jythoner 写道
wjason 写道jythoner 写道avanry 写道String.valueOf()和charAt()这两个方法用的好啊!但是上个方法在做下一道题的时候会有问题计算1-400亿有多少个1?很奇怪, 楼主既然想到了这个问题, 问什么还给出上面的答案呢.呵呵,因为简单的问题有简单的解法,如果是400亿的话,主要是靠找规律,然后计算。和1000这种小数字不同,虽然1000也可以使用找规律的算法,但如果是2343这种没规律的数字的话,难度会增加。
hand, hand.
想法完全一致 呵呵.
为了这个任意数字,
我还现找了一个数学系的同学讨论了一下.
我们得出了999...9的规律
当问及任意数字的时候.
他的建议是让我再找个搞组合数学的....
14 楼
lyazure
2009-02-06
个位含1的每10个有一个
十位含1的每100个有10个,同样相当于每10个有1个
百位含1的每1000个有100个,同样相当于每10个有1个
以此类推……
所以,1~1000里1的个数等于1000/10+1000/10 + 1000/10 + 1 = 301
进一步归纳: 1~(10^n-1)里1的个数是n*10^(n-1)
1~1000 分成 1~999,1000,就可以算出3*10^2 +1=301
所以只要对一个数字进行分解就可以了
1~400亿的话,1~(10^10-1)含有10*10^(10-1)个,1~400亿就是4*10^10 + 1
任意数字可以同样拆开算:56786435可以分成1~50000000-1,50000000~56000000-1,56000000~56700000-1,……
十位含1的每100个有10个,同样相当于每10个有1个
百位含1的每1000个有100个,同样相当于每10个有1个
以此类推……
所以,1~1000里1的个数等于1000/10+1000/10 + 1000/10 + 1 = 301
进一步归纳: 1~(10^n-1)里1的个数是n*10^(n-1)
1~1000 分成 1~999,1000,就可以算出3*10^2 +1=301
所以只要对一个数字进行分解就可以了
1~400亿的话,1~(10^10-1)含有10*10^(10-1)个,1~400亿就是4*10^10 + 1
任意数字可以同样拆开算:56786435可以分成1~50000000-1,50000000~56000000-1,56000000~56700000-1,……
13 楼
sjynt131
2009-02-06
public class CountOne {
public static void main(String[] args) {
long count = 0;
long lastNum=1201345002;
count=countNumber(lastNum,1);
System.out.println(count);
}
public static long countNumber(long lastNum,long countNum){
long count=0;
String lastNumStr=String.valueOf(lastNum);
long length=lastNumStr.length();
if(countNum>0){
for(long i=length;i>0;i--){
long mode=(long)Math.pow(10,i-1);
long bitNum=lastNum/mode%10;
if(bitNum>0){
long modeNum=lastNum%mode;
if(bitNum>countNum){
count=count+bitNum*(i-1)*mode/10+mode;
}else if(bitNum==countNum){
count=count+bitNum*(i-1)*mode/10+modeNum+1;
}else{
count=count+(i-2)*10;
}
}
}
}else{
for(long i=0;i<=length-1;i++){
long mode=(long)Math.pow(10,i+1);
long modeNum=lastNum*10/mode%10;
long lastMode=lastNum%mode;
long upNum=lastNum/mode;
if(i==0){
count=count+upNum+1;
}
else{
if(modeNum==0){
count=count+(upNum-1)*mode/10+1+lastMode;
}
else{
count=count+upNum*mode/10;
}
}
}
}
return count;
}
}
public static void main(String[] args) {
long count = 0;
long lastNum=1201345002;
count=countNumber(lastNum,1);
System.out.println(count);
}
public static long countNumber(long lastNum,long countNum){
long count=0;
String lastNumStr=String.valueOf(lastNum);
long length=lastNumStr.length();
if(countNum>0){
for(long i=length;i>0;i--){
long mode=(long)Math.pow(10,i-1);
long bitNum=lastNum/mode%10;
if(bitNum>0){
long modeNum=lastNum%mode;
if(bitNum>countNum){
count=count+bitNum*(i-1)*mode/10+mode;
}else if(bitNum==countNum){
count=count+bitNum*(i-1)*mode/10+modeNum+1;
}else{
count=count+(i-2)*10;
}
}
}
}else{
for(long i=0;i<=length-1;i++){
long mode=(long)Math.pow(10,i+1);
long modeNum=lastNum*10/mode%10;
long lastMode=lastNum%mode;
long upNum=lastNum/mode;
if(i==0){
count=count+upNum+1;
}
else{
if(modeNum==0){
count=count+(upNum-1)*mode/10+1+lastMode;
}
else{
count=count+upNum*mode/10;
}
}
}
}
return count;
}
}
12 楼
sun_cyj
2009-02-06
sun_cyj 写道
虽然时间不多...但是大数据就有优势了
原来我错了...INDEXOF这个计算比循环还多...
11 楼
sun_cyj
2009-02-06
虽然时间不多...但是大数据就有优势了
10 楼
sun_cyj
2009-02-06
public static void main(String[] args) { System.out.println(System.nanoTime()); int count = 0; for (int i = 1; i <= 1000; i++) { String s = String.valueOf(i); if(s.indexOf("1") != -1) for (int j = 0; j < s.length(); j++) { if (s.charAt(j) == '1') count++; } } System.out.println(count); System.out.println(System.nanoTime()); }
算了下..比楼主的要快一点..呵.
9 楼
chyy001
2009-02-05
外面在加层循环就可以算出来了
8 楼
chyy001
2009-02-05
重发一遍,上面解释有点问题
/**
* 计算数组中1的个数
* @param str
* @return
*/
public static int count(int[] str)
{
int k = str.length;
//计数器
int count = 0;
// 寻找1
while(k >= 1 && str[k]==1)
{
count ++;
}
return count ;
}
/**
* 计算数组中1的个数
* @param str
* @return
*/
public static int count(int[] str)
{
int k = str.length;
//计数器
int count = 0;
// 寻找1
while(k >= 1 && str[k]==1)
{
count ++;
}
return count ;
}
7 楼
chyy001
2009-02-05
我把它转成数组int[] str:
public static int count(int[] str)
{
//初始化
int k = str.length;
//计数器
int count = 0;
//寻找到最右边的0
while(k >= 1 && str[k]==1)
{
count ++;
}
return count ;
}
6 楼
jythoner
2009-02-05
wjason 写道
jythoner 写道avanry 写道String.valueOf()和charAt()这两个方法用的好啊!但是上个方法在做下一道题的时候会有问题计算1-400亿有多少个1?很奇怪, 楼主既然想到了这个问题, 问什么还给出上面的答案呢.
呵呵,因为简单的问题有简单的解法,如果是400亿的话,主要是靠找规律,然后计算。和1000这种小数字不同,虽然1000也可以使用找规律的算法,但如果是2343这种没规律的数字的话,难度会增加。
5 楼
wjason
2009-02-05
jythoner 写道
avanry 写道String.valueOf()和charAt()这两个方法用的好啊!但是上个方法在做下一道题的时候会有问题计算1-400亿有多少个1?
很奇怪, 楼主既然想到了这个问题, 问什么还给出上面的答案呢.
我也思考了一下, 简单说一下思路
0的个数 | 范围
9 | 1 - 99
180 | 100 - 999
2700 | 1000 - 9999
36000 | 10000 - 99999
-------------------------------------
38889(合计结果)
接下来是488889
5888889
... 知道n
另:1到999999999999999999.....之间
1..9这九个数字的个数相同.
所以到400亿, 这个数字好求.
到任意数字,比如 56786435, 则要难一些.
这个需求有点复杂,
还没想好,
我得好好回忆一下我的数学知识.....
en pass...
4 楼
elam
2009-02-05
全变成字符拼接在一起
然后遍历一遍数出来
然后遍历一遍数出来
3 楼
JimyChen
2009-02-05
valueOf 方法
返回指定对象的原始值。
object.valueOf( )
charAt 方法
返回指定索引位置处的字符。
strObj.charAt(index)
返回指定对象的原始值。
object.valueOf( )
charAt 方法
返回指定索引位置处的字符。
strObj.charAt(index)
2 楼
jythoner
2009-02-05
avanry 写道
String.valueOf()和charAt()这两个方法用的好啊!
但是上个方法在做下一道题的时候会有问题
计算1-400亿有多少个1?
1 楼
avanry
2009-02-04
String.valueOf()和charAt()这两个方法用的好啊!
发表评论
-
用Java解PythonChallenge(第二天)
2009-08-02 11:49 14033. import java.io.BufferedRea ... -
用Java解PythonChallenge(第一天)
2009-08-01 21:20 2495www.pythonchallenge.com是一个学习pyt ... -
Java每日一题24(最后一题)
2009-03-06 11:10 1628昨天又写了个双色球程序,作为Java每日一题系列的终止符: J ... -
Java每日一题23
2009-03-05 11:23 3190来个数学性强的,c语言书中找到的 有13个人围成一圈,从第一 ... -
Java每日一题22
2009-03-04 09:45 2660开始新一轮的学习吧,今天来个比较有意思的 有一个字符串Stri ... -
Java每日一题21
2009-03-03 10:26 1694也是出自C的,不过都是跟数学相关的,最看重算法 明天开始回归正 ... -
Java每日一题20
2009-03-02 10:56 2368纪念每日一题出到第20期 最近在看Linux下的c开发,所以把 ... -
Java每日一题19
2009-02-27 10:03 2301今天是周末,再来一道没有答案的题,没事的朋友coding下,放 ... -
Java每日一题18
2009-02-26 11:11 2065今天来点新鲜的,来一道我没答案的题 现将TEXT1.TXT中 ... -
Java每日一题17
2009-02-25 11:27 1953编写一个JAVA程序,从输入的一个字符串中提取出数字并组成一个 ... -
Java每日一题16
2009-02-24 11:25 1508最近项目开始了,比较繁忙,所以发题只能等到快到午饭的休息时间, ... -
Java每日一题15
2009-02-23 10:40 2086时间系列的题暂时告一段落,在此期间,这些问题有了很多新的解决方 ... -
Java每日一题14
2009-02-20 11:29 2080热烈庆祝我的blog被选入javaeye论坛的首页滚动栏!!! ... -
Java每日一题13
2009-02-19 11:00 1557编程实现将用户输入的24小时制时间转换为12小时制时间 找到 ... -
Java每日一题12
2009-02-18 12:10 1410如何得到一年的所有星期二的日期? package test2 ... -
Java每日一题11
2009-02-17 10:58 1873根据一个TimeZone的时间,比如一个“Africa/Acc ... -
Java每日一题10
2009-02-16 10:19 2293看到有越来越多的人来参与到我的Java每日一题系列,非常开心: ... -
Java每日一题09
2009-02-13 10:50 1737准备从下星期开始推出”时间处理系列“,”字符串系列“,”打印格 ... -
Java每日一题08
2009-02-12 10:31 2424编写一个辅助小学生学习乘法的程序。使用一个Random对象产生 ... -
Java每日一题07
2009-02-11 11:00 2809通过键盘输入一个字符串,判断字符串中出现最多的字符并输出该字符 ...
相关推荐
Java每日一题20160906,每日一道Java编程题,提高自己
NULL 博文链接:https://duyiwuer.iteye.com/blog/362849
NULL 博文链接:https://duyiwuer.iteye.com/blog/353541
NULL 博文链接:https://jythoner.iteye.com/blog/344407
java每日一练练习题
NULL 博文链接:https://duyiwuer.iteye.com/blog/351913
Java方向每日一题day17_11月24日编程题答案1
Java方向每日一题day18_11月25日编程题答案1
java面试题,参考面试使用,与什么不懂的不用联系我,我随便传的东西,不传不让下载,真烦
比特科技制作[编程题]44581-寻找第K大链接:https://www.nowcoder.com/questionTerminal/e016ad9b7f0b4
1. 执行如下程序,输出结果是( ) 3. 下列选项中属于面向对象设计方法主要特征的是( ) 6. 在基本 JAVA 类型中,如果不明确指定,整数型的默认是 _
整理互联网常见面试题,为春招、校招和社招做准备。如若不能下载,关注公众号“每日技术分享”,可免费下载资源。
干货资源推荐: JVM干货调试视频教程分享 50份优秀Java求职者简历 SpringCloud前后端分离实战项目...本资源整理自互联网,仅供学习交流使用,请勿商用,坚持每日分享一套Java学习资源干货,一起提高,一起进步!!!
leetcode-java:每日一题leetcode-java版
9. 以下关于java封装的描述中,正确的是: 1. 标题:DNA序列 | 时间限制:1秒 | 内存限制:32768K 2. 标题:百万富翁问题 | 时间限制:
1. 以下哪项是类实例化的语句 6. 变量a是一个64位有符号的整数,初始值用16进制表示为:0Xf000000000000000 7. HashSet子类依靠
推出了每日一题活动。借此打卡! ID Difficulty Solution Series Finish Time Java C C++ Address 1 ☆ 2019-02-29 ✓ 225 ☆ 每日一题 2020-03-01 ✓ 206 ☆ 每日一题 2020-03-02 ✓ 面试题 ☆ 每日一题 2020-03-03...
一些考试的java习题,一些试卷,考生可能用处大点
leetcode 答案 leetcode-java 每日更新一题,Java编写的LeetCode算法题目答案。
Leetcode每日LeetCode每日一题Java实现