求一个正整数是由哪几个连数(连续的正整数)相加

题目描述:随便给出一个正整数, 求出这个数是由哪几个正整数相加,要求相加的这几个数是连续的。

如: 7+8=15,4+5+6=15,1+2+3+4+5=15

 

 

Test.java:

 

package com.joe;

 

public class Test
{
 public static void main(String[] args)
 {
  int v = 2;
  do {
   v++;
   Test.F(v, 1);
  } while (v <= 100);
 }
 
 //给出正整数v, 求出它是哪几个连数相加的结果(连数:如2,3,4或4,5)
 public static void F(int value, int base)
 {
  Node node = new Node();
  int halfValue = value / 2;
  boolean flag = false;
  if(base <= halfValue)
  {
   int sum = 0;
   int i = base;
   while(true)
   {
    sum += i;
    if(sum == value)   //找到一个这样的组合
    {
     node.start = base;
     node.end = i;
     node.Display(value);
     flag = true;   //针对当前的value,找到至少一个这样的组合
    }
    if(sum >= value)   //寻找下一个组合
    {
     sum = 0;
     base++;     //修改开始位置
     if(base <= halfValue)
      i = base;
     else     //已经不可能再有组合了
      break;
    }
    else
     i++;
   }
   if(flag)
    System.out.println();
  }
 }
}

Node.java:

package com.joe;


public class Node
{
 public int start;
 public int end;
 
 public void Display(int v)
 {
  System.out.print(v + " = ");
  for(int i = start; i <= end; i++)
  {
   if(i - start > 0)
    System.out.print(" + ");
   System.out.print(i);
  }
  System.out.println();
 }
}

运行结果很清楚了!

 

下面仅修改了一下Test.java中的F(),用递归来实现。实际上并没有很强的递归思想,只是形式上是递归的,比较好看,代码如下:

//给出正整数v, 求出它是哪几个连数相加的结果(连数:如2,3,4或4,5)
 public static void F(int value, int base)
 {
  Node node = new Node();
  int halfValue = value / 2;
  
  if(base <= halfValue)
  {
   int sum = 0;
   int halfCeil = (int) Math.ceil(value * 0.5);
   for(int i = base; i <= halfCeil ; i++)
   {
    sum += i;
    if(sum == value)   //找到一个这样的组合
    {
     node.start = base;
     node.end = i;
     node.Display(value);
    }
    if(sum >= value)   //本轮查找结束,跳出循环
    {
     F(value, base + 1);  //开始寻找下一个组合
     break;
    }
   }
  }
 }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/407863.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CF卡引导IOS惊魂记(二)

接着昨天昨天头比较晕&#xff0c;没有理清思路&#xff0c;今天着重思考几个问题&#xff1a;CF卡的问题&#xff1b;网络为什么不能引导的问题&#xff1b;Flash是否有问题&#xff1b;&#xff08;1&#xff09;CF卡昨天一开始测试时候既然是好的&#xff0c;那么一定是后面…

react(88)--ant design控制inputNumber设置正整数

})(<InputNumberformatter{limitDecimals}parser{limitDecimals}placeholder"请输入助力人数"min{0}/>)} const limitDecimals (value) > {return value.replace(/^(0)|[^\d]/g, );};

求一个正整数是哪几个正整数相加的和,这些数不能相同

问题描述&#xff1a;求一个正整数是哪几个正整数相加的和 (这些数要各不相同) 说明&#xff1a;给定一个正整数&#xff0c;如8&#xff0c;要求输出以下数组&#xff0c;因为他们的和为8&#xff1a; [1, 2, 5] [1, 3, 4] [1, 7] [2, 6] [3, 5] [8] 代码是一个牛人写的…

管理学

管理学<?xml:namespace prefix o ns "urn:schemas-microsoft-com:office:office" />第一 什么是管理学管理学有两种认识&#xff1a;其一&#xff0c;运筹学(Operation Research)是一门运用科学&#xff0c;并不是纯粹的数学&#xff0c;它具有多学科交叉的…

react(89)--设置只能正整数

<InputNumber// formatter{limitDecimals}// parser{limitDecimals}precision{0}placeholder"请输入助力人数"min{0}/>

bootstrap学习笔记(一)网络系统

注&#xff1a;我是根据自己理解写的 有参考http://www.w3cschool.cc/bootstrap该教程。 bootstrap目前有两种默认的网络&#xff08;格&#xff09;系统&#xff1a;一个是940px,另一个是12列。 我们先从12列入手看看&#xff1a; 1.Bootstrap 使用 CSS 的 class "row&q…

最简单的java单例

最简单的java单例源代码&#xff1a; class Singleton{ private Singleton() { } public static Singleton instance null; public static Singleton getInstance() { if(instance null) instance new Singleton(); return instance; } public static void main(String…

委托笔记

刚写了段程序&#xff0c;总算稍微理解了下委托&#xff0c;留下备忘。 定义&#xff1a; 1 publicdelegatestringDelegateTest(stringsss);类中实例化委托&#xff1a; 1 publicclassTestClass2 {3 publiceventDelegateTest _delegateTest;4 5 publicstringBeginDelegate()6 {…

react(90)--时间戳比较

if (new Date(values.activityTimeStamp[1]).getTime() <new Date(values.openTimeStamp[0]).getTime()) {message.error(开放给商户提报的结束时间要大于等于活动开始时间);return false;}

primefaces 带参数的组件

分析了一下primefaces extension showcase的源码&#xff0c;总结一下组件传参的方式。 下面定义了一个组件&#xff0c;名为fourTabsDecoratorCustom.xhtml 1: <html xmlns"http://www.w3.org/1999/xhtml" 2: xmlns:h"http://xmlns.jcp.org/jsf/html&…

枚举windows进程

将当前运行的进程列举出来(C Code): #include<windows.h>#include<tlhelp32.h>//#include <iomanip>#include<iostream>using namespace std; int main(){ int count0; PROCESSENTRY32 pe32; //使用这个数据之前设置大小 pe32.dwSizesiz…

程序员的职业发展

在中国有很多人都认为IT行为是吃青春饭的&#xff0c;如果过了30岁就很难有机会再发展下去&#xff01;其实现实并不是这样子的&#xff0c;现在过30岁的已经慢慢多起来了&#xff0c;也不见得混得不好。下面结合自己的经历&#xff0c;与大家一起探讨一下。 明确入行的目的 很…

C++ 20 协程总结

C 20 协程总结 介绍 C 20提供的是非对称的、一等对象、无栈的协程&#xff08;Coroutines in C20 are asymmetric, first-class, and stackless&#xff09; 所谓协程&#xff0c;即用户级线程&#xff0c;一种用于将异步代码同步化的编程机制&#xff0c;使得程序的执行流可…

VC++6.0开发环境之快捷键

F1&#xff1a; 帮助 CtrlO &#xff1a;Open CtrlP &#xff1a;Print CtrlN &#xff1a;New CtrlShiftF2 &#xff1a;清除所有书签 F2 &#xff1a;上一个书签 ShiftF2 &#xff1a;上一个书签 AltF2 &#xff1a;编辑书签 Ctrl&#xff0b;F2 &#xff1a;添加/删除一个书…

react(92)--批量删除进行置空操作

//批量删除handleDeleteAll () > {this.props.dispatch({type: startpage/updateState,payload: { selectedRowKeys: [] },});const { selectedRowKeys } this.props.startpage;if (selectedRowKeys.length 0) {message.error(当前未选择);return false;}this.deletePoin…

.net程序员的盲点(八):泛型

1.泛型介绍泛型类和泛型方法同时具备可重用性、类型安全和效率&#xff0c;这是非泛型类和非泛型方法无法具备的。泛型通常用在集合和在集合上运行的方法中。.NET Framework 2.0 版类库提供一个新的命名空间System.Collections.Generic&#xff0c;其中包含几个新的基于泛型的集…

C++20 协程实现线程同步示例

C20 协程实现线程同步示例 class Event { public:Event() default;Event(const Event&) delete;Event(Event&&) delete;Event& operator(const Event&) delete;Event& operator(Event&&) delete;class Awaiter;Awaiter operator co_await…

react(93)--成功置空

//删除页面逻辑的封装deletePointsDefinition (list) > {this.props.dispatch({type: activity/deleteActivityPopup,payload: {codeList: list,},callback: (res) > {console.log(res, res);if (res.returnCode 0) {message.success(操作成功);\this.props.dispatch({…

给窗口设置系统级或窗口级的热键

开发环境&#xff1a;VS2005, C#语言 为了给一个程序加一个系统级的热键&#xff0c;在开发时需要使用到下面的代码&#xff0c;就是在程序中注册和卸载热键。 1。首先在Form1类的函数中添加如下代码&#xff1a; [DllImport("user32.dll")] private static…