mirror of
https://github.com/balkian/gists.git
synced 2024-11-22 01:32:29 +00:00
Add 'repos/9186870/' from commit '9cfc2da26524287f6166cc20ca88ad568f762143'
git-subtree-dir: repos/9186870 git-subtree-mainline:766153a055
git-subtree-split:9cfc2da265
This commit is contained in:
commit
44c3bd604a
38
repos/9186870/array_combination.ipynb
Normal file
38
repos/9186870/array_combination.ipynb
Normal file
@ -0,0 +1,38 @@
|
||||
{
|
||||
"metadata": {
|
||||
"name": "Untitled0"
|
||||
},
|
||||
"nbformat": 3,
|
||||
"nbformat_minor": 0,
|
||||
"worksheets": [
|
||||
{
|
||||
"cells": [
|
||||
{
|
||||
"cell_type": "code",
|
||||
"collapsed": false,
|
||||
"input": "a=set([3,4])\nb=set([3,7])\nc=set([4])\n",
|
||||
"language": "python",
|
||||
"metadata": {},
|
||||
"outputs": [],
|
||||
"prompt_number": 6
|
||||
},
|
||||
{
|
||||
"cell_type": "code",
|
||||
"collapsed": false,
|
||||
"input": "def array_combinations(*args):\n combinations = [set([i]) for i in set(args[0])]\n for arg in args[1:]:\n tempcomb = []\n for i in set(arg):\n for c in combinations:\n c.update([i])\n tempcomb.append(c)\n if tempcomb:\n combinations = tempcomb\n return combinations\nres = array_combinations(a,b,c)\nprint res\nprint len(res)",
|
||||
"language": "python",
|
||||
"metadata": {},
|
||||
"outputs": [
|
||||
{
|
||||
"output_type": "stream",
|
||||
"stream": "stdout",
|
||||
"text": "[set([3, 4, 7]), set([3, 4, 7]), set([3, 4, 7]), set([3, 4, 7])]\n4\n"
|
||||
}
|
||||
],
|
||||
"prompt_number": 25
|
||||
}
|
||||
],
|
||||
"metadata": {}
|
||||
}
|
||||
]
|
||||
}
|
13
repos/9186870/frozen_combination.py
Normal file
13
repos/9186870/frozen_combination.py
Normal file
@ -0,0 +1,13 @@
|
||||
def frozen_combination(*args):
|
||||
combinations = set([frozenset(),])
|
||||
for arg in args:
|
||||
tempcomb = set(frozenset(),)
|
||||
for i in set(arg):
|
||||
tempcomb.update(set([frozenset(list(c)+[i]) for c in combinations if i not in c]))
|
||||
if len(tempcomb) > 0:
|
||||
combinations = tempcomb
|
||||
return combinations
|
||||
# return [set(comb) for comb in combinations] # for sets instead of frozensets
|
||||
res = frozen_combination(a,b)
|
||||
print res
|
||||
print len(res)
|
Loading…
Reference in New Issue
Block a user