C# : Collections
Top 37 C# Example Pages...

[".wsl...rty. [+BiCST~~}T~~YFG776669F+BBCCXBXaBCC_BCCZCBE.BXS}T~~}T~~","Change, coins."," Change is made with a recursive method. This sort of problem, as described in the Structure and Interpretation of Computer Programs, can be solved with recursion.","This implementation"," in the C# language is illustrative. For most of these puzzles, implementing the code yourself (with a little help) is a good way to learn. ","Recursion ","recursion","Example."," This program uses recursion to compute different ways of making change to match a specified amount. Change() will print out all the ways you can make change for a specified amount. ","Example: ","If you specify 51 cents, it will tell you can make this out of 36 1-cent coins and three 5-cent coins.","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","Based on:"," .NET 4.5\n\n","C# program that counts change","\n\nusing System;\nusing System.Collections.Generic;\nusing System.Linq;\n\nclass Program\n{\n static void Main()\n {\n List<int> coins = new List<int>();\n List<int> amounts = new List<int>() { 1, 5, 10, 25, 50 };","\n //\n // Compute change for 51 cents.\n //\n ","Change","(coins, amounts, 0, 0, 51);\n }\n\n static void ","Change","(List<int> coins, List<int> amounts, int highest, int sum, int goal)\n {","\n //\n // See if we are done.\n //\n ","if (sum == goal)\n {\n Display(coins, amounts);\n return;\n }","\n //\n // See if we have too much.\n //\n ","if (sum > goal)\n {\n return;\n }","\n //\n // Loop through amounts.\n //\n ","foreach (int value in amounts)\n {","\n //\n // Only add higher or equal amounts.\n //\n ","if (value >= highest)\n {\n List<int> copy = new List<int>(coins);\n copy.Add(value);\n ","Change","(copy, amounts, value, sum + value, goal);\n }\n }\n }\n\n static void Display(List<int> coins, List<int> amounts)\n {\n foreach (int amount in amounts)\n {\n int count = coins.Count(value => value == amount);\n Console.WriteLine(\"{0}: {1}\",\n amount,\n count);\n }\n Console.WriteLine();\n }\n}\n\n","Output: partial","\n\n1: 51\n5: 0\n10: 0\n25: 0\n50: 0\n\n1: 46\n5: 1\n10: 0\n25: 0\n50: 0\n\n1: 41\n5: 2\n10: 0\n25: 0\n50: 0\n\n1: 41\n5: 0\n10: 1\n25: 0\n50: 0\n\n1: 36\n5: 3\n10: 0\n25: 0\n50: 0","Notes, above program."," The 2 List instances declared store the currently recorded values (which starts empty), and the amounts or denominations of coins that are possible to be used. ","List ","list","Int ","int","Note: ","The program emphasizes the recursive Change method. This implements the logic that actually computes the change.","Tip: ","In many recursive methods, it is clearest to add the exit conditions at the start of the function.","Notes, Change method."," Change() first tests for the ideal amount, and if this is reached, it prints it to the screen. It tests to make sure the change collected has not exceeded the target. ","If ","if","Notes, size."," This algorithm only adds coins in increasing size. It starts with the 1-cent coin and continues with the 5-cent coin and then larger coins. The output is automatically sorted.","Output."," Display() prints the frequencies of the coins that can be added together to reach the target value. In the example, all of the output will add up to 51 cents. ","Console.WriteLine ","console","The first output: ","It shows 51 cents being composed of 51 1-cent coins. This is obviously a correct answer.","The second output: ","It shows 51 cents being made up of 46 1-cent coins and one 5-cent coin.","SICP."," The Structure and Interpretation of Computer Programs book uses this example in its first chapter. It counts ways to compute change for 100 cents. See section 1.2.2 Tree Recursion. ","SICP text: mit.edu ","https://mitpress.mit.edu/sicp/full-text/book/book-Z-H-11.html#%_sec_1.2","Answer: ","The answer of 292 is computed from interpreting the Lisp program. On the C# program shown here, you will also get 292 answers.","Also: ","If you modify the program to include a counter, it is clearer that the result is 292.","Performance."," This program is far from ideal for performance. A variety of approaches could be used to transform the process into a faster one. ","Tip: ","You could use arrays instead of List types, and could use a Stack structure instead of a recursive method.","Arrays ","array","Stack ","stack","Performance, continued."," You could improve the loop with a faster algorithm that jumps to the correct starting index based on the current top value. This could be done with a lookup table. ","Foreach ","foreach","A summary."," We wrote an example program that makes change to match a specified amount. It uses a recursive method invocation and the List type to solve a puzzle. ","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","url()","url()","url()"]

["url()","url()","url()","url()","url()","url()","url()","url()"]