牛客NC381 累加序列【中等 深度优先DFS, Java,Go,PHP】

题目

在这里插入图片描述
题目链接:
https://www.nowcoder.com/practice/ff244079fdaf4d8f9767887ec9582043

思考

利用递归不断找到合适的字符串转成数值满足要求

参考答案Java

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     *
     * @param arr string字符串
     * @return bool布尔型
     */
    public boolean AdditiveArray (String arr) {
        return dfs(arr, arr.length(), 0, 0, 0, 0);
    }

    //利用递归不断找到合适的字符串转成数值满足要求
    public boolean dfs(String s, int n, int index, long sum, long pre, int k) {
        if (index == n ) return k > 2; //k大于2符合题目要求
        for (int i = index; i < n ; i++) {
            int left = index, right = i;
            if (left < right && s.charAt(left) == '0') continue;

            long cur = 0;
            while (left <= right) {
                cur = cur * 10 + (s.charAt(left++) - '0');
            }

            if (k >= 2 && cur != sum) continue;

            if (dfs(s, n, i + 1, cur + pre, cur, k + 1)) return true;
        }

        return false;
    }
}

参考答案Go

package main



/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 *
 * @param arr string字符串
 * @return bool布尔型
 */
func AdditiveArray(arr string) bool {
	// write code here
	return Dfs(arr, 0, 0, 0, 0)
}

// 利用递归不断找到合适的字符串转成数值满足要求
func Dfs(s string, index int, sum int, pre int, cnt int) bool {
	if index == len(s) && cnt > 2 {
		return true
	}

	for i := index; i < len(s); i++ {
		left := index
		right := i
		if left < right && s[left] == '0' {
			continue
		}

		var cursum int = 0
		for left <= right {
			cursum = (int)(cursum*10) + (int)(s[left]-'0')
			left++
		}

		if cnt >= 2 && cursum != sum {
			continue
		}

		if Dfs(s, i+1, cursum+pre, cursum, cnt+1) {
			return true
		}
	}
	return false
}

参考答案PHP

<?php


/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param arr string字符串 
 * @return bool布尔型
 */
function AdditiveArray( $arr )
{
   return dfs($arr,0,0,0,0);
}
//利用递归不断找到合适的字符串转成数值满足要求
function dfs($s,$index,$next,$pre,$cnt){
    //var_dump('index:'.$index.'  sum:'.$sum.'  pre:'.$pre.'  cnt:'.$cnt);
    if($index == strlen($s) && $cnt >2) return true;
    for($i=$index;$i<strlen($s);$i++){
        $left = $index;
        $right = $i;
        if($left<$right && $s[$left] =='0') continue;

        $cursum =0;
        while ($left<=$right){
            $cursum=$cursum*10+intval($s[$left++]);
        }

        if($cnt>=2 && $cursum !=$next) continue;
        if(dfs($s,$i+1,$cursum+$pre,$cursum,$cnt+1)){
            return true;
        }
    }
    return false;
}
  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

赵长辉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值