3.6. Dictionary¶
C# also provides us a structure to store data as key/value pairs. C# calls
these objects dictionaries, and they are
provided by the Dictionary
class.
Considering the gradebook example, we can improve our program using a dictionary. We’ll store the students’ grades along with their names in the same data structure. The names will be the keys, and the grades will be the values.
As with the other collection structures, in C# we must specify the types of the objects we’ll be storing when we declare a variable or parameter to be a dictionary. This means specifying both key and value data types, which are allowed to be different types for a given dictionary.
We suggest you run another version of the gradebook program called DictionaryGradebook
in Visual Studio.
This program lives in the csharp-web-dev-controlflowandcollections repository.
If you haven’t forked and cloned the repository, you should do so now.
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | Dictionary<string, double> students = new Dictionary<string, double>();
string newStudent;
Console.WriteLine("Enter your students (or ENTER to finish):");
// Get student names and grades
do
{
Console.WriteLine("Student: ");
string input = Console.ReadLine();
newStudent = input;
if (!Equals(newStudent, "")) {
Console.WriteLine("Grade: ");
input = Console.ReadLine();
double newGrade = double.Parse(input);
students.Add(newStudent, newGrade);
// Read in the newline before looping back
Console.ReadLine();
}
} while(!Equals(newStudent, ""));
// Print class roster
Console.WriteLine("\nClass roster:");
double sum = 0.0;
foreach (KeyValuePair<string, double> student in students) {
Console.WriteLine(student.Key + " (" + student.Value + ")");
sum += student.Value;
}
double avg = sum / students.Count;
Console.WriteLine("Average grade: " + avg);
|
Notice how a Dictionary
called students
is declared on line 11:
11 | Dictionary<string, double> students = new Dictionary<string, double>();
|
Here, <string, double>
defines the data types for this dictionary’s
<key, value>
pairs.
We can add a new item with a .Add()
method, specifying both key and
value:
26 | students.Add(newStudent, newGrade);
|
And while we don’t do so in this example, we may also access Dictionary
elements using bracket notation. If we had a key/value pair of
"jesse"/4.0
in the students
dictionary, we could access the grade with:
double jesseGrade = students["jesse"];
Variables may be used to access elements:
1 2 | string name = "jesse";
double jesseGrade = students[name];
|
Looping through a dictionary is slightly more complex than it is for ordered lists.
Let’s look at the foreach
loop from this example:
38 39 40 41 | for (KeyValuePair<string, double> student in students) {
Console.WriteLine(student.Key + " (" + student.Value + ")");
sum += student.Value;
}
|
The iterator variable, student
, is of type
KeyValuePair<string, double>
. The class KeyValuePair<T,T> is specifically
constructed to be used in this fashion, to represent key/value pairs
within dictionaries. Each KeyValuePair
object has a Key
property and a
Value
property.
If you only need to access the key of each item, you can
construct a simpler loop and use the Keys
property of the Dictionary
class:
1 2 3 | foreach (string studentName in students.Keys) {
Console.WriteLine(studentName);
}
|
A similar structure applies if you only need the values, using
students.Values
:
1 2 3 | foreach (double grade in students.Values) {
Console.WriteLine(grade);
}
|
Note
We can declare and initialize a dictionary in one stroke like so:
1 2 3 4 5 6 | Dictionary<int, string> groceries = new Dictionary<int, string>
{
{2, "Apples"},
{3, "Oranges"},
{1, "Avocado"}
};
|
3.6.1. Dictionary Methods¶
Let’s collect some Dictionary
methods as we have for List
. As we
said about Lists
, this is by no means a comprehensive catalog. For full
details on all properties and methods available, see the documentation on the Dictionary
class.
For the purposes of this table, we’ll create a dictionary to hold our solar system’s planets and the number of moons associated with each.
1 2 3 4 5 6 7 8 9 | Dictionary<string, int> moons = new Dictionary<string, int>();
moons.Add("Mercury", 0);
moons.Add("Venus", 0);
moons.Add("Earth", 1);
moons.Add("Mars", 2);
moons.Add("Jupiter", 79);
moons.Add("Saturn", 82);
moons.Add("Uranus", 27);
moons.Add("Neptune", 14);
|
C# Syntax |
Description |
Example |
---|---|---|
|
Returns the number of items in the dictionary, as an |
|
|
Returns a collection containing all keys in the dictionary. This collection may be used in a
|
|
|
Returns a collection containing all values in the dictionary. This collection may be used in a
|
|
|
Add a key/value pair to a dictionary. |
|
|
Returns a boolean indicating whether or not the dictionary contains a given key. |
|
|
Returns a boolean indicating whether or not the dictionary contains a given value. |
|
We have only brushed the surface of how arrays, Lists
, and dictionaries work.
We leave it to you to refer to the official documentation linked below for more
details. You’ll certainly be using Lists
and dictionaries in more ways than
those covered in this lesson, but with the knowledge you have now, you
should be able to use C# collections and learn new uses as you go.
3.6.2. Check Your Understanding¶
Question
Given our Dictionary
,
1 2 3 4 5 6 7 8 9 10 | moons = {
"Mercury" = 0,
"Venus" = 0,
"Earth" = 1,
"Mars" = 2,
"Jupiter" = 79,
"Saturn" = 82,
"Uranus" = 27,
"Neptune" = 14
}
|
What is the syntax to get the key names?
Dictionary.Keys(moons);
moons.Keys();
moons.Keys;
moons.KeySet();
Question
Given our Dictionary
,
1 2 3 4 5 6 7 8 9 10 | moons = {
"Mercury" = 0,
"Venus" = 0,
"Earth" = 1,
"Mars" = 2,
"Jupiter" = 79,
"Saturn" = 82,
"Uranus" = 27,
"Neptune" = 14
}
|
What will moons["Mars"];
return?
2
{Mars: 2}
2.0
"Mars"