Decomposition of Numbers
NumberDecompose expresses a number into multiples of units, like currency denominations.
The Bahamian currency (BSD) uses the following banknote denominations.
In[1]:=
data:image/s3,"s3://crabby-images/2147b/2147b6c5d13d7cffd2bee0e5bcf94ae7b4fb0f32" alt="Click for copyable input"
denominations = {100, 50, 20, 10, 5, 3, 2, 1, 1/2};
BSD allows for more possible ways of breaking a given amount into bills relative to other currencies due to the presence of the BSD 3 note. These are the quotients between consecutive denominations.
In[2]:=
data:image/s3,"s3://crabby-images/c4cff/c4cffcc44cdd327d9a4267906ce4a7f19e32cf6b" alt="Click for copyable input"
Divide @@@ Subsequences[denominations, {2}]
Out[2]=
data:image/s3,"s3://crabby-images/97d96/97d965f4b952b07ea1ee77d8abafdeadc0493823" alt=""
In most currency systems, only quotients 2 and 5/2 are present, but in this case there are also 5/3 and 3/2.
In[3]:=
data:image/s3,"s3://crabby-images/4c1e2/4c1e29f5bf9a51e6708da5d66edbcff636ad0034" alt="Click for copyable input"
Divide @@@ Subsequences[denominations, {2}];
BarChart[%]
Out[3]=
data:image/s3,"s3://crabby-images/51334/51334d1a18a959648e3d4b2ea6e5ea140df38fe3" alt=""
Decompose an amount of Bahamian dollars in the available banknote denominations.
In[4]:=
data:image/s3,"s3://crabby-images/3bde5/3bde504993ee5aa71944217045798072cb82c660" alt="Click for copyable input"
NumberDecompose[598.50, denominations]
Out[4]=
data:image/s3,"s3://crabby-images/56754/56754ce34efc867ddd1f7a497ba8be96cbc20caf" alt=""
Recover the initial amount using NumberCompose.
In[5]:=
data:image/s3,"s3://crabby-images/2077f/2077f9b9de41a5d63b8341a12d1d777be85a104b" alt="Click for copyable input"
NumberCompose[{5, 1, 2, 0, 1, 1, 0, 0, 1.}, denominations]
Out[5]=
data:image/s3,"s3://crabby-images/57ddf/57ddffa96c3e5e04a074264bb74b800384699ca0" alt=""
This is the amount of money obtained with a banknote of each denomination.
In[6]:=
data:image/s3,"s3://crabby-images/23a96/23a965374724e0473c01505385b950e3632b4a6b" alt="Click for copyable input"
NumberCompose[Table[1, Length@denominations], denominations] // N
Out[6]=
data:image/s3,"s3://crabby-images/d3cc4/d3cc48b5758be7f17cfe4d16e9bf2e26964d9e77" alt=""