Re: How to find the difference between two lists (opposite of union[]?)
- To: mathgroup at smc.vnet.net
- Subject: [mg119910] Re: How to find the difference between two lists (opposite of union[]?)
- From: Priyan Fernando <priyan.fernando at gmail.com>
- Date: Wed, 29 Jun 2011 05:28:42 -0400 (EDT)
This should work: mList = RandomInteger[{1, 1000}, 1000] // Sort entirerange = Range[1, 1000] Complement[entirerange, mList] We basically find the complement of your set of random numbers and the entirerange(1...1000) On 28 June 2011 17:25, McHale, Paul <Paul.McHale at excelitas.com> wrote: > I have been working through a neat book called Mathematica(r): A > Problem-Centered Approach< > http://www.amazon.com/Mathematica%C2%AE-Problem-Centered-Approach-Undergraduate-Mathematics/dp/1849962502/ref=sr_1_2?ie=UTF8&qid=1309181549&sr=8-2>. > I have a problem I would like to know if there is a more elegant solution. > I would think involving set theory, but I can't seem to (embarrassingly) > find it. > > I want to generate 1000 random integers between 1 and 1000. Then find out > what numbers between 1 and 1000 were not generated. > > (* Generate random list of 1000 numbers with range 1-1000*) > mList=RandomInteger[{1,1000},1000] //Sort; > > (* Find out what numbers were omitted in the range 1-1000*) > (* Make a list of numbers 1-1000 with position of each within original > array *) > mList=Table[{i,Position[mList,i] //Flatten},{i,1,1000}]; > > (* select numbers with no position in original array (musical chairs) *) > Select[mList,Length[#[[2]]]==0&][[All,1]] > > This works creating a lot of extra array in the process. Just wanted to > ask what are the methods you guys would use to solve this? > > A funny (non-working) way of stating the same thing would be: > > (* Generate random list of 1000 numbers with range 1-1000*) > mList=RandomInteger[{1,1000},1000] //Sort; > > Solve[ Join[mList,mDiff]==Range[1000],mDiff] > > Thanks, > Paul > > > Paul McHale | Electrical Engineer, Energetics Systems | Excelitas > Technologies Corp. > > Phone: +1 937.865.3004 | Fax: +1 937.865.5170 | Mobile: +1 > 937.371.2828 > 1100 Vanguard Blvd, Miamisburg, Ohio 45342-0312 USA > Paul.McHale at Excelitas.com<mailto:Paul.McHale at perkinelmer.com> > www.excelitas.com<http://www.excelitas.com> > > [cid:image001.png at 01CB9136.E3D96D90] > > Please consider the environment before printing this e-mail. > This email message and any attachments are confidential and proprietary to > Excelitas Technologies Corp. If you are not the intended recipient of this > message, please inform the sender by replying to this email or sending a > message to the sender and destroy the message and any attachments. > Thank you > -- Thanks and Regards, Priyan Fernando Mob. +94 772 622 368