Power set: Difference between revisions

RPL: add section
m (BBC BASIC moved to the BASIC section.)
(RPL: add section)
Line 3,695:
<pre>
{{},{1},{2},{1,2},{3},{1,3},{2,3},{1,2,3},{4},{1,4},{2,4},{1,2,4},{3,4},{1,3,4},{2,3,4},{1,2,3,4}}
</pre>
 
=={{header|RPL}}==
{{works with|Halcyon Calc|4.2.8}}
{| class="wikitable"
! RPL code
! Comment
|-
|
'''IF''' DUP SIZE
'''THEN''' LAST OVER SWAP GET → tail
≪ LIST→ 1 - SWAP DROP →LIST POWST
1 OVER SIZE '''FOR''' j
DUP j GET tail + 1 →LIST + '''NEXT'''
'''ELSE''' 1 →LIST '''END'''
≫ ''''POWST'''' STO
|
'''POWST''' ''( { set } -- { power set } )''
if set is not empty
then store tail
get power set of { set } - tail
for all sets of { set } - tail power set
add tail to set, then set to power set
else return { { } }
|}
{ 1 2 3 4 } '''POWST'''
{ } '''POWST'''
 
{{out}}
<pre>
2: { { } { 1 } { 2 } { 1 2 } { 3 } { 1 3 } { 2 3 } { 1 2 3 } { 4 } { 1 4 } { 2 4 } { 1 2 4 } { 3 4 } { 1 3 4 } { 2 3 4 } { 1 2 3 4 } }
1: { { } }
</pre>
 
Line 3,748 ⟶ 3,784:
#<Set: {#<Set: {}>, #<Set: {1}>, #<Set: {2}>, #<Set: {1, 2}>, #<Set: {3}>, #<Set: {1, 3}>, #<Set: {2, 3}>, #<Set: {1, 2, 3}>}>
</pre>
 
 
=={{header|Rust}}==
1,151

edits