【第02题】给定 n,求 1 + 2 + 3 + ... + n 的和 | 四种解法

剑指 Offer 57 - II. 和为s的连续正数序列
输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)。序列内的数字由小到大排列,不同序列按照首个数字从小到大排列。

/*
1.输入一个正整数 target ,输出所有和为 target 的连续正整数序列(至少含有两个数)
2.序列内的数字由小到大排列,不同序列按照首个数字从小到大排列*/
class Solution {//使用滑动窗口来处理相关的数据
    public int[][] findContinuousSequence(int target) {
        int left = 0;//窗口的左边界
        int right = 1;//设置窗口的右边界
        int sum = left + right;//对两者的数进行求和
        ArrayList<int []> list = new ArrayList<>();//将用来存放将要记录的数据
        //根据左窗口的数字必须小于target / 2 ,否则就不满足连续正整数序列等于target
        while(left <= target / 2) { 
            if(sum < target) {//当窗口内的数值小于target就将右窗口边界向右移动一位
                sum += ++right;
            }else if(sum > target){//当窗口的数值大于target则将左窗口的边界向右移动一位
                sum -= left++;
            }else {
                //如果找到等于target的数,就将其记录下来,同时向右移动左右边界
                int [] arr = new int[right - left + 1];//定义一个数组来记录等于target的数
                for(int n = left; n <= right; n ++) {
                    arr[n - left] = n;//遍历
                }
                list.add(arr);//添加在集合中
                //左边和右边同时往右移一位
                sum -= left++;
                sum += ++right;
            }
        }
        return list.toArray(new int [list.size()][]);//转化为数组
    }
}

总结:这里面的相关的边界问题要注意,在判断窗口值左右边界值自增时,注意条件是否满足。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 目描述: 给定一个正整数n,1/1+1/2+1/3+...+1/n的和。 解思路: 使用循环遍历1到n,将每个数的倒数加起来即可。 代码实现: ```python n = int(input("请输入一个正整数:")) sum = for i in range(1, n+1): sum += 1/i print("1/1+1/2+1/3+...+1/n的和为:", sum) ``` 输出示例: ``` 请输入一个正整数:5 1/1+1/2+1/3+...+1/n的和为: 2.283333333333333 ``` ### 回答2: 这道目其实考察的是一个数学知识——等差数列和公式,所以我们先来回顾一下。 设一个等差数列的首项为a1,公差为d,项数为n,那么这个等差数列的和Sn可以表示为: Sn = (n/2)(a1 + an) 其中,an表示这个等差数列的第n项。 那么,回到这道目中,我们可以发现,这个要的n分之一序列是一个等差数列,因为序列中每一项都是前一项除以n得到的。 我们设这个等差数列的首项为1,公差为1/n,项数为n,那么这个等差数列的第n项an可以表示为: an = 1/n 那么,我们就可以利用等差数列和公式来出这个等差数列的和Sn了: Sn = (n/2)(a1 + an) = (n/2)(1 + 1/n) = n/2 + 1/2 因此,n分之一序列前n项和就是n/2 + 1/2。 需要注意的是,在计算时,我们要保留小数点后的数字,因为这个结果可能会是一个分数或者是一个无理数。 ### 回答3: 这道我们计算一个分数数列的前 n 项和,即 1/n+1/(n+1)+…+1/(2n-1)+1/(2n)。 首先,我们可以将每一项的分母表示为 n+i-1,其中 i 表示在序列中的位置,即第一项 i=1,第二项 i=2,以此类推。 因此,我们可以得到和式为 1/n+1/(n+1)+…+1/(2n-1)+1/(2n) = (1/n+1/(n+1))+…+(1/(2n-1)+1/(2n))。 接下来,我们将每一对括号中的两个数相加并化简,得到: (1/n+1/(n+1))+(1/(n+2)+1/(n+3))+…+(1/(2n-2)+1/(2n-1))+1/(2n) 再将每一对括号中的两个数的和化简为 (2n+i-1)/(n(i+n-1)),即可得到原式的简化形式: (2n+1)/(n(2n+1)) 因此,要计算原式的值,只需将上式中的 n 替换为给定的 n,即可得到答案。 总结来说,这道虽然涉及分数数列和,但是通过一定的数学思维和演算,我们可以简化和式,并得到规律,从而得到解法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值