Ruby

["*0|ruby;-ruby",["EB^CEKPY]","OCPEMOJCOLIAMEIIMILLOIICFAFIJIKAIGLAOIMAKIOCLA","OOOCYFGDHDADADADADGDAGDFSTUUUUTTUUUUOCCPADADGDHDGDHDFOCCOCPGDGDHDHDGDFOPGDADADGDADFOCCPGDGDHDGDHDFADADOCCPGDADADGDHDRDFOCCPGDGDHDGDHDGDHDFADADADAOCCPGDGDHDRDFOCPGDGDRDFOBCPGDGDHDRDFOCBPGDHDGDHDGDHDADFAOCCCPGDGHDAGDFOBPGDRDRDGDHDFOCCPGDGDHDADGDFOCPADADGDRDFADAOBOBOBCOWSTTUUUUTTUUUU",".wfj..r...rrl.ttrfe.r..t..","Keyword","Array","Hash","String","2D","Case","Class","Console","Convert","DateTime","Duplicates","Exception","File","Format","If","Iterator","Math","Method","Nil","Number","Rand","Recursion","Regexp","Set","Sort","Split","Sub","Substring","While","Array."," A crystal has many sides. It reflects in the light. Shadows play on its surface. Much like a crystal an array has many parts.","To create a Ruby array,"," we use the Array class. We can omit \"Array\" and just use the initializer. Or we can assign each element as we go along.","New Array."," We first construct a new array with 4 integer elements. Then we modify the first element (at index 0). We display the array values. They are stored in the specified order. ","First element: ","The first element in an array is located at index 0, not 1. This is standard for most programming languages.","Based on:"," Ruby 2\n\n","Ruby program that uses array","\n\n","# An array of integers.\n","values = ","Array","[","10",", ","20",", ","30",", ","40","]","\n\n# Modify the first element.\n","values[0] = ","100","\n\n# Display the array.\n","puts values\n\n","Output","\n\n100\n20\n30\n40","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","6227126509","data-ad-format","auto","First, last."," In life there is always a beginning and an end. This is true too in an array where at least one element exists. First and last are helpful methods. ","Warning: ","In a zero-element array, first and last return nil. So we must check the result if our array may be empty.","Info: ","The first array element is located at the index 0. And the last is located at the position equal to length minus one.","Ruby program that uses first, last","\n\nelements = [","\"ruby\"",", \"diamond\", ","\"gold\"","]","\n\n# First is the 0 index.\n","puts elements.","first","\nputs elements[0]","\n\n# Last index is length minus one.\n","puts elements.","last","\nputs elements[elements.length - 1]\n\n","Output","\n\nruby\nruby\ngold\ngold","Mutable."," Arrays are mutable. When we modify an element, no array copy is made. The element is simply replaced. In algorithms that change elements, these mutable arrays help improve speed. ","Sizing: ","Arrays are automatically resized. We have no need to specify how many elements will eventually be stored in them.","Terms: ","It is a topic of debate whether Array is technically a List. Often in languages, an Array is not resizable, but a list is.","Push."," This method adds the specified element value to the end of the array. This is possible with a mutable collection. Here we start with an empty array. ","And: ","We add the string \"tree\" and then \"grass\" to the array. The first element is \"tree.\" The last is \"grass.\"","Ruby program that uses push","\n\n","# Create an empty array.\n","values = Array[]","\n\n# Push two elements.\n","values.","push","(\"tree\")\nvalues.","push","(\"grass\")","\n\n# Print elements.\n","print \"First: \", values.first, \"\\n\"\nprint \"Last: \", values.last, \"\\n\"\n\n","Output","\n\nFirst: tree\nLast: grass","Push, operator."," This is an alternative to the push method. It does the same thing but requires less source code. The << operator can be chained. Many elements can be added in one statement. ","Ruby program that uses append operator","\n\nitems = Array[]","\n# Append two strings, one after another.\n","items ","<<"," \"cat\" ","<<"," \"dog\"","\n# Append another element.\n","items ","<<"," \"bird\"\n\np items\n\n","Output","\n\n[\"cat\", \"dog\", \"bird\"]","Delete."," An array element can be deleted. When this occurs, the slot in the array is eliminated. Elements that come after are shifted forward. ","Delete_at: ","With delete_at(), we remove an element by specifying its index. No search is required.","Delete: ","With delete(), we remove the first element of the specified value. We remove the \"lime\" element without knowing its index.","Ruby program that deletes elements","\n\n","# Citrus fruits.\n","arr = Array[\"orange\", \"lemon\", \"lime\"]","\n\n# Delete element at index 1.\n","arr.","delete_at","(1)\nputs \"Fruit:\", arr","\n\n# Delete element with value of \"lime\".\n","arr.","delete","(\"lime\")\nputs \"Fruit:\", arr\n\n","Output","\n\n","Fruit:","\norange\nlime\n","Fruit:","\norange","Delete_if."," This method receives a block that evaluates to true or false. The block is tested against each element in the array. If it evaluates to true, the element is deleted. ","Block: ","The block must be surrounded by curly brackets. In the block, we supply a name for our element variable.","Here: ","I use \"e.\" Another name like \"x\" could instead be used. The expression deletes all elements with values >= 40.","Ruby program that uses delete_if","\n\n","# An array of integers.\n","numbers = [10, 20, 30, ","40",", ","50","]","\n\n# Delete numbers greater than or equal to 40.\n","numbers.","delete_if"," {","|e|"," e >= 40}\nputs numbers\n\n","Output","\n\n10\n20\n30","Pop, empty."," The pop method deletes the final element in an array. It simplifies the syntax for this operation. Empty(), also shown, returns true if an array has zero elements. ","Here: ","We create an array of three elements. We then pop it three times, yielding an empty array.","Tip: ","The final array element is removed each time pop() is called. The actual array is modified\u2014no copy is created.","Ruby that pops an array","\n\n","# Create and display an array.\n","names = Array[\"Conrad\", \"James\", \"Joyce\"]\nputs names, \"\"","\n\n# Pop the last element.\n","names.","pop","()\nputs names, \"\"","\n\n# Pop again.\n","names.","pop","()\nputs names, \"\"","\n\n# Pop again and see if the array is empty.\n","names.","pop","()\nputs names.empty?\n\n","Output","\n\nConrad ","3 elements","\nJames\nJoyce\n\nConrad ","2 elements","\nJames\n\nConrad ","1 element","\n\ntrue ","0 elements","Each."," Any loop can iterate over an array. But some methods, called iterators, make looping over an array more elegant. They reduce complexity. They reduce possible errors. ","Syntax: ","We declare an iteration variable between two vertical bars. It is important to learn the syntax here.","Tip: ","Each() enumerates over each element in the array. Here we use the identifier \"number\" to access elements.","Ruby that uses each","\n\n","# Some Wagstaff primes.\n","primes = [3, 11, 43, 683, 2731]","\n\n# Loop over primes and display them.\n","primes.","each"," do ","|number|","\n puts number\nend\n\n","Output","\n\n3\n11\n43\n683\n2731","Each, short syntax."," Ruby is known for its expressive, glittering syntax. Here we use a short syntax form to write an iterator on one line. ","Tip: ","We omit the \"do\" keyword and use curly brackets. This style makes it harder to add more statements.","Ruby that uses each, short syntax form","\n\n","# Some even numbers.\n# ... Let's get even.\n","evens = [2, 4, 6, 8]","\n\n# Use short syntax form for the iterator block.\n","evens.each {","|ev|"," puts ev}\n\n","Output","\n\n2\n4\n6\n8","Each_index."," Sometimes we want to access all indexes in an array. This can be done with a loop, but the each_index iterator is also available. It yields all the indexes of the array. ","For Loop ","while-ruby","Here: ","We use each_index over a three-element array. It has indexes 0, 1 and 2. We print them.","Ruby that uses each_index","\n\n","# Array has indexes 0, 1 and 2.\n","values = [\"cat\", \"dog\", \"sheep\"]","\n\n# Loop over all indexes in the array.\n","values.","each_index"," do ","|index|","\n puts index\nend\n\n","Output","\n\n0\n1\n2","Index."," This searches an array for the specified element. It starts its search at the beginning and proceeds to the following elements. If it finds the element, it returns its index value. ","Important: ","If index() does not find the specified element, it returns nil. This is a special object.","Nil ","nil-ruby","Ruby that uses index","\n\nitems = [\"Boots\", \"Cloak\", \"Dagger\"]","\n\n# Get index of this element.\n","result = items.","index","(\"Cloak\")\nputs result","\n\n# Call index again.\n","result = items.","index","(\"Dagger\")\nputs result","\n\n# Call index with nonexistent element.\n","result = items.","index","(\"Helmet\")\nif result == nil\n puts \"","Not found","\"\nend\n\n","Output","\n\n1\n2\n","Not found","For-loop."," In the range of the for-loop, we can specify an array's lowest and highest indexes. To loop over the entire array, we specify the highest valid index as the maximum of the range. ","So: ","We start at zero. We progress to the inclusive maximum of the array's length minus one. We then access each element.","Advantages: ","With a for-loop, we can use the index in the loop iteration for other operations. We can access adjacent elements in the array.","Usually: ","The simplest syntax possible for an operation is best. This leads to simpler (and thus higher-quality) programs.","Ruby that uses for-loop, array","\n\n","# An array with four strings.\n","values = [\"cat\", \"dog\", \"rabbit\", \"giraffe\"]","\n\n# Loop over all indexes in the array.\n","for"," i in ","0..values.length-1","\n # Access the element.\n ","puts values[i]\nend\n\n","Output","\n\ncat\ndog\nrabbit\ngiraffe","Uniq."," This removes all duplicate elements. We also can use the \"uniq!\" method to modify the array in-place. In this example, we call uniq to eliminate two duplicate element (a 1 and 4). ","Remove Duplicates ","duplicates-ruby","Ruby that uses uniq","\n\n","# Contains some duplicate elements.\n","values = [1, ","1",", 2, 3, 4, ","4","]","\n\n# Remove non-unique elements in-place.\n","values.","uniq!","\nputs values\n\n","Output","\n\n1\n2\n3\n4","Collect."," This applies (maps) each element in an array to a new value based on a function. For example we can multiply each element by two. With \"collect!\" the array is modified in-place. ","Map: ","In other languages like Python, the map() built-in has similar functionality as collect.","Block: ","The syntax for collect requires a block. In this code we use the identifier \"e,\" but other identifiers work just as well.","Ruby that uses collect","\n\n","# Contains three elements.\n","elements = [1, 0, 100]","\n\n# Use collect to multiply all elements by 2.\n","result = elements.","collect","{|e| ","e * 2","}","\n\n# Display the result array.\n","p result\n\n","Output","\n\n[2, 0, 200]","Ranges."," With range syntax we can change parts of arrays in single operations. So we can replace a range of elements with a series of new elements. We can insert ranges this way. ","Tip: ","Single elements too can be assigned. And often assigning one element at the time is easiest.","Ruby that assigns range of elements","\n\nelements = [","10",", 20, 30, 40, ","50","]","\n\n# Assign range of elements at indexes 1, 2, and 3 to a new array.\n","elements[","1..3","] = [100, 200]\nputs elements\n\n","Output","\n\n","10","\n100\n200\n","50","Sort, reverse."," Arrays have sort() and reverse() methods. With sort, we can specify a block to sort elements by a method. In this way we implement ascending and descending sort orders. ","Sort, reverse ","sort-ruby","Copy."," How can we copy an array? The slice syntax is helpful here. We take a total-array slice. And this returns (with little hassle) a copied array. ","Copy Array ","copy-array-ruby","Two-dimensional."," We can create arrays of arrays\u20142D arrays. These are jagged arrays. Each subarray can have a different length. We can use 2D array indexing syntax here. ","2D Array ","2d-ruby","Flatten: ","The flatten method converts a multidimensional array into one dimension. It copies all nested arrays.","Arrays are powerful."," They are resizable. They can be searched and tested. As a result, they are used in many programs. They often form of the basis of other classes and collections.","With array methods,"," we avoid repetitive code. This leads to clearer syntax forms and better programs. With arrays in Ruby, we build on solid foundations. ","br","ins","class","adsbygoogle","data-ad-client","ca-pub-4712093147740724","data-ad-slot","3679700504","data-ad-format","link","br","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()","url()","url()","url()","url()","url()","url()","url()","url()","url()","url()","A","url()"]