`
slowman
  • 浏览: 38374 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

有道算法题之一

阅读更多

 

 

一个大公司的笔试题目如下:

  题目如下: 写一个类,实现这样一个方法,此方法给定两个参数N、L(均为整数) N是一个自然数,L表示一个长度。要求此函数输出一个最小长度的连续数的数组,此数组的几个连续数的和要等于给定的N,并且该数组的长度 要大于等于给定的L。如没有满足该条件的则返回一个空数组{}。

eg1: (18,3)则应该return {5,6,7}; 分析满足和为18的连续数的数组有两个:{3,4,5,6}、{5,6,7} 应题目要求输出最短的数组,所以结果如上。

eg2: (18,4) 则应该返回结果{3,4,5,6};

eg3:(45,10)则返回结果为{0,1,2,3,4,5,6,7,8,9};

 

本人尝试着写出了一个算法,现在贴出来,跟大家讨论一下.希望大家提供最好的解决方案.

package cn.edu.ccnu.inc.algorithm;

/**
 * 题目如下: 写一个类,实现这样一个方法,此方法给定两个参数N、L(均为整数) N是一个自然数,L表示一个长度。要求此函数输出一个最小长度的连续
 * 数的数组,此数组的几个连续数的和要等于给定的N,并且该数组的长度 要大于等于给定的L。如没有满足该条件的则返回一个空数组{}。 eg1:
 * (18,3)则应该return {5,6,7}; 分析满足和为18的连续数的数组有两个:{3,4,5,6}、{5,6,7}
 * 应题目要求输出最短的数组,所以结果如上。 eg2: (18,4) 则应该返回结果{3,4,5,6}; eg3:
 * (45,10)则返回结果为{0,1,2,3,4,5,6,7,8,9};
 *
 * @author 桂子山上一棵草
 * @email :slowguy@qq.com
 * @date 2009年10月21日
 *
 */

public class NL {

 static int min; // 记录连续数组的最小长度

 static int start; // 最小连续数组的起始位置

 public static void showResults(int N, int L)
 {
  int array[] = new int[N + 1];
  for (int i = 0; i <= N; i++)
  { // 如: array[3] ={0,1,2,3}
   array[i] = i; // 初始化

  }
  int total = 0;
  int num = 0;
  for (int i = 0; i <= N; i++)
  {
   total += array[i];
   num++;
   if (total == N && num >= L)
   {
    System.out.print("找到了一组结果:");
    int k = i - num + 1;
    if (min == 0)
    {
     min = num;
     start = k;
    } else if (num < min)
    {
     min = num;
     start = k;
    }
    while (k <= i)
    {
     System.out.print(array[k] + "  ");
     k++;
    }
    System.out.println("");
   }
   if (total > N)
   {
    total = 0;
    i = i - num + 1;
    num = 0;
   }
  }
  if (min == 0)
  {
   System.out.println("{}");
  } else
  {
   System.out.print("最小长度连续数组为: ");
   int i = 0;
   System.out.print("{");
   while (i < min)
   {
    System.out.print(" " + array[start + i]);
    i++;
   }
   System.out.print("}");
  }
 }

 public static void main(String[] args)
 {

  int N = 45;
  int L = 3;
  showResults(N, L);

 }

}

 

 

测试结果如下:



 

  • 大小: 15.1 KB
0
2
分享到:
评论
1 楼 slowman 2009-10-23  
怎么没有人讨论一下呢。

相关推荐

    网易有道笔试题第一部分偏产品策划知识.doc

    网易有道笔试题第一部分偏产品策划知识.doc

    有道饭团 网易有道编程挑战题

    ### 有道饭团网易有道编程挑战题详解 #### 题目背景与目标 在当前企业规模不断扩大、员工数量日益增长的情况下,行政部门的工作负担也随之增加,特别是针对员工发票报销这一环节。为了减轻行政人员的工作压力并...

    有道编程挑战题 网易

    接下来,每一组6位比特会被转换为一个范围在0到63之间的整数。由于Base64编码使用了一个由64个字符组成的字符集,因此可以将这四个整数映射到相应的Base64字符。 #### Base64字符集 Base64字符集包括以下64个字符...

    2011.9 有道浙大机试题

    2011.9 有道浙大机试题 有兴趣的可以下下来看看 算法和概率的比较多

    有道单词本.xml 有道单词本.xml 有道单词本.xml

    有道单词本.xml 可以导入到有道单词里面

    有道翻译Python爬虫(sign算法)

    在实际的Python爬虫开发中,你可以将这个签名算法封装成一个函数,每次调用有道翻译API时,先计算出签名,然后与其他请求参数一起发送。这样,即使API接口发生变化,只要签名算法不变,仍能保证请求的正确性。 需要...

    有道词典《每日一句》经典收藏.pdf

    有道词典《每日一句》经典收藏.pdf

    Java调用有道翻译

    在IT行业中,调用外部服务来增强应用功能是一种常见的做法,比如使用有道翻译API来实现文本翻译。本文将详细讲解如何在Java环境下调用有道翻译API,以实现高效、便捷的多语言翻译功能。 首先,有道翻译API提供了一...

    网易2017校园招聘 网易有道笔试题.pdf

    这篇文档主要包含两个编程题目,都是关于数据处理和序列操作的。下面分别对这两个题目进行详细解释。 **题目一:模拟洗牌过程** ...在实际编程中,这样的问题可能出现在数据处理、算法设计或者游戏开发等场景。

    2010年有道难题资格赛试题3套

    标题 "2010年有道难题资格赛试题3套" 暗示了这是一个包含编程竞赛或逻辑思维挑战的资源包,特别是来自2010年网易有道的资格赛题目。有道是中国知名的在线学习平台,尤其以其编程挑战和逻辑测试闻名。这些试题可能...

    前端项目源码:模仿有道云,个人制作的一款多人协同的云笔记.zip

    前端项目源码:模仿有道云,个人制作的一款多人协同的云笔记 前端项目源码:模仿有道云,个人制作的一款多人协同的云笔记 前端项目源码:模仿有道云,个人制作的一款多人协同的云笔记 前端项目源码:模仿有道云,...

    有道API翻译Demo

    【有道API翻译Demo】是基于C#编程语言和WinForm界面设计的一个示例应用,主要展示了如何利用有道翻译API实现词汇的便捷翻译功能。这个Demo为开发者提供了一个直观的参考,帮助他们理解如何在自己的项目中集成有道...

    网易有道离线安装包下载

    网易有道离线安装包下载,适合于无法上网的环境

    有道翻译浏览器插件

    有道浏览器目前可用的google浏览器在线划词插件,不用去google商店下载了

    有道笔记最新版

    【有道笔记最新版】是网易旗下的一款高效笔记应用,旨在帮助用户轻松地在不同设备间同步和管理自己的笔记内容。这款软件具有强大的云同步功能,使得用户可以在手机、平板、电脑等多终端之间无缝切换,随时随地查看和...

    迷你有道翻译.rar

    在实际应用中,迷你有道翻译的置顶功能可能依赖于操作系统级别的窗口管理API,这些API允许程序控制自身的显示位置和层级,使其始终在其他窗口之上。此外,程序可能还集成了快捷键功能,用户可以通过预设的键盘组合...

    仿有道网易预览

    【标题】"仿有道网易预览"是一个项目,旨在模仿有道网易的网页预览功能,这种功能常见于搜索引擎或新闻聚合网站中,能够提供一个网页的缩略视图,用户无需点击链接就能大致了解页面内容。这个项目可能包含了实现这一...

    一个模拟163上有道标签页的日历

    【标题】:“一个模拟163上有道标签页的日历”指的是通过编程技术实现的一款功能类似于163邮箱中“有道日历”的应用程序。在163邮箱中,有道日历是一款实用的在线日程管理工具,允许用户查看日期、添加事件、设置...

    有道笔记

    2. 数据存储:有道笔记的核心功能之一是笔记的同步,这涉及到分布式存储和数据一致性问题。可能采用了类似Git的版本控制机制,确保不同设备间的数据同步无冲突,并且支持历史版本回溯。 3. 云服务:有道笔记的云...

    jdk1.8有道翻译版

    1. **lambda表达式**:这是JDK1.8最重要的新特性之一,它允许以更简洁的方式表示匿名函数,使得代码更加紧凑和易读。Lambda表达式与函数式接口紧密关联,如`Runnable`、`Comparator`等,它们在集合操作、事件处理等...

Global site tag (gtag.js) - Google Analytics