找出给定数组的子数组,该子数组和恰好为给定目标数t----动态规划/递归/搜索(待完成)

Posted koliverpool

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了找出给定数组的子数组,该子数组和恰好为给定目标数t----动态规划/递归/搜索(待完成)相关的知识,希望对你有一定的参考价值。

编写一个函数,传入一个int型数组,返回该数组能否分成两组,使得两组中各元素加起来的和相等,并且,所有5的倍数必须在其中一个组中,所有3的倍数在另一个组中(不包括5的倍数),能满足以上条件,返回true;不满足时返回false。 

输入描述:

第一行是数据个数,第二行是输入的数据

输出描述:

返回true或false

输入例子:
4
1 5 -5 1

输出例子:

true
v1=int(raw_input())
v2=raw_input().split( )
v2=map(int,v2)
a=[]
b=[]
c=[]
for i in v2:
    if i%3==0 and i%5!=0:
        a.append(i)
    elif i%5==0:
        b.append(i)
    else:
        c.append(i)
a1=sum(a)
b1=sum(b)
c1=sum(c)
dif=abs(a1-b1)
#x-y=dif
#x+y=c1
x=(dif+c1)%2
y=(c1-dif)%2
if x==0 and y==0:###如果x,y均为0,也就是x1有整数解,才有可能找到满足结果的数组,接下来就是判断,在a中或者b中,能否找到子数组和恰好为x1
    x1=(dif+c1)/2
    c1=sorted(c1)
    ads=0
    lis=[]
    i=0
    while ads<=x1:
        lis.append(c1[i])
        ads+=c1[i]
        i+=1
    print true
else:
    print false

 

以上是关于找出给定数组的子数组,该子数组和恰好为给定目标数t----动态规划/递归/搜索(待完成)的主要内容,如果未能解决你的问题,请参考以下文章

给定一个整数数组和一个目标值,找出数组中和为目标值的两个数 例如给定nums = [2,7,11,15],target = 9

给定一个数组和一个目标整数,找出数组中两数之和和整数相等的数

python实现给定一个数和数组,求数组中两数之和为给定的数

LeetCode 第一题 两数之和

1两数之和

求数组中两数之和等于给定的值