新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> We choose to study algorithmic problems,  not because they are easy,  but because they are hard.
    [返回] 计算机科学论坛计算机理论与工程『 算法理论与分析 』 → [分享]上次笔试题目,抛砖引玉 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 13213 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: [分享]上次笔试题目,抛砖引玉 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     wcdxyl 帅哥哟,离线,有人找我吗?天秤座1980-10-9
      
      
      威望:4
      等级:大四(每天看1小时莱昂氏)(版主)
      文章:158
      积分:1145
      门派:IEEE.ORG.CN
      注册:2006/3/14

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给wcdxyl发送一个短消息 把wcdxyl加入好友 查看wcdxyl的个人资料 搜索wcdxyl在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看wcdxyl的博客楼主
    发贴心情 [分享]上次笔试题目,抛砖引玉

    import java.util.Calendar;
    /**
     一个自然数n,求从1开始到这个数之间有多少个1。
     比如11就有3个1
    */


    class FN{

     public long getFN(long n){
      long num = 0;

      for(long  i = 1;i<=n;i++){ //1,2,3,4.....
       String allnum = String.valueOf(i);
       if(allnum.indexOf("1")==-1) continue;//去掉没有1的

       for(int j = 0;j<allnum.length();j++){//遍历之间的每个数
        if((allnum.substring(j).indexOf("1"))!=-1) num++;
       }
      }
      return num;
     }

     public static void main(String[] args){
      if(args[0]!=null){
       Calendar c = Calendar.getInstance();
       long start = c.getTimeInMillis();

       long param = Long.parseLong(args[0]);
       System.out.println(new FN().getFN(param));

       Calendar b = Calendar.getInstance();
       long end = b.getTimeInMillis();
       System.out.println(end-start);

      }
     }
    }

    这个算法求数18991耗时100毫秒,考官说好的可以十几毫秒


       收藏   分享  
    顶(0)
      




    ----------------------------------------------
    主页:http://wcdxyl.blogchina.com
    MSN:wcdxyl@163.com

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/3/22 16:25:00
     
     DavidPotter 帅哥哟,离线,有人找我吗?
      
      
      等级:大三暑假(ITELS考了6.5分!)
      文章:150
      积分:852
      门派:Lilybbs.net
      注册:2006/3/7

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给DavidPotter发送一个短消息 把DavidPotter加入好友 查看DavidPotter的个人资料 搜索DavidPotter在『 算法理论与分析 』的所有贴子 点击这里发送电邮给DavidPotter 引用回复这个贴子 回复这个贴子 查看DavidPotter的博客2
    发贴心情 
    穷举也太死板了,应该分析给定参数来判断。
    ps: 楼主的算法不对吧。
    for(int j = 0;j<allnum.length();j++){//遍历之间的每个数
        if((allnum.substring(j).indexOf("1"))!=-1) num++;
    如果数是21那么这时你的num++应该走了2次。还不如用charAt(j);

    ----------------------------------------------
    Don‘t try so hard, the best things come when you least expect them to.

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/15 18:26:00
     
     zhangmei1988521 帅哥哟,离线,有人找我吗?
      
      
      等级:大一(高数修炼中)
      文章:12
      积分:96
      门派:XML.ORG.CN
      注册:2006/6/15

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给zhangmei1988521发送一个短消息 把zhangmei1988521加入好友 查看zhangmei1988521的个人资料 搜索zhangmei1988521在『 算法理论与分析 』的所有贴子 点击这里发送电邮给zhangmei1988521 引用回复这个贴子 回复这个贴子 查看zhangmei1988521的博客3
    发贴心情 
    穷举也太死板了,应该分析给定参数来判断。
    ps: 楼主的算法不对吧。
    for(int j = 0;j<allnum.length();j++){//遍历之间的每个数
        if((allnum.substring(j).indexOf("1"))!=-1) num++;
    如果数是21那么这时你的num++应该走了2次。还不如用charAt(j);
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/15 22:36:00
     
     jassyking 帅哥哟,离线,有人找我吗?
      
      
      等级:大一新生
      文章:0
      积分:58
      门派:XML.ORG.CN
      注册:2006/3/30

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给jassyking发送一个短消息 把jassyking加入好友 查看jassyking的个人资料 搜索jassyking在『 算法理论与分析 』的所有贴子 引用回复这个贴子 回复这个贴子 查看jassyking的博客4
    发贴心情 
    好像有公式吧
    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/17 11:36:00
     
     phoenixinter 帅哥哟,离线,有人找我吗?水瓶座1987-2-12
      
      
      威望:1
      头衔:Ikki
      等级:大四(GRE考了1600分!)(版主)
      文章:127
      积分:1126
      门派:Lilybbs.net
      注册:2005/3/14

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给phoenixinter发送一个短消息 把phoenixinter加入好友 查看phoenixinter的个人资料 搜索phoenixinter在『 算法理论与分析 』的所有贴子 点击这里发送电邮给phoenixinter  引用回复这个贴子 回复这个贴子 查看phoenixinter的博客5
    发贴心情 
    递归的搞,很快的……Shanghai 2004 C

    ----------------------------------------------
    phoenixinter
    algorithm bm@lilybbs
    ikki@poj

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2006/6/19 18:57:00
     
     GoogleAdSense水瓶座1987-2-12
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 算法理论与分析 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/15 12:09:12

    本主题贴数5,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    62.500ms