Solved

How to write LINQ query

Posted on 2014-12-22
4
91 Views
Last Modified: 2016-02-15
Hi, yet another LINQ query. My apologies I cannot get the hang of this. This should be simple. My code is below.
Thank you
John

using System;
using System.Collections.Generic;
using System.Linq;

namespace ConsoleApplication5
{
    class Program
    {
        static void Main(string[] args)
        {
            Dictionary<int, List<Single>> test = new Dictionary<int, List<Single>>();

            test.Add(1, new List<Single> { 1f, 2f, 3f, 4f });
            test.Add(15, new List<Single> { 1.1f, 2f });
            test.Add(99, new List<Single> { 1.1f, 1f, 2f });

            int totalNumberOfValues = test.Sum(n => n.Value.Count());   //returns 9 which is correct

            //the distinct values are 1f, 2f, 3f, 4f, 1.1f, counting them there are 5 values
            //I want to count them
            int totalNumberOfDistinctValue = what goes here;      //I want this to be 5
        }
    }
}

Open in new window

0
Comment
Question by:John Bolter
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
4 Comments
 
LVL 34

Accepted Solution

by:
it_saige earned 500 total points
ID: 40513104
You would use:
int totalNumberOfDistinctValue = test.SelectMany(n => n.Value).Distinct().Count();

Open in new window


Example -
using System;
using System.Collections.Generic;
using System.Linq;

namespace EE_Q28585282
{
	class Program
	{
		static void Main(string[] args)
		{
			Dictionary<int, List<Single>> test = new Dictionary<int, List<Single>>();

			test.Add(1, new List<Single> { 1f, 2f, 3f, 4f });
			test.Add(15, new List<Single> { 1.1f, 2f });
			test.Add(99, new List<Single> { 1.1f, 1f, 2f });

			int totalNumberOfValues = test.Sum(n => n.Value.Count());   //returns 9 which is correct
			Console.WriteLine(string.Format("Total number of values: {0}", totalNumberOfValues));

			//the distinct values are 1f, 2f, 3f, 4f, 1.1f, counting them there are 5 values
			//I want to count them
			int totalNumberOfDistinctValue = test.SelectMany(n => n.Value).Distinct().Count();      //I want this to be 5
			Console.WriteLine(string.Format("Total number of distinct values: {0}", totalNumberOfDistinctValue));
			Console.ReadLine();
		}
	}
}

Open in new window


Produces the following output -Capture.JPG
More on SelectMany - http://msdn.microsoft.com/en-us/library/system.linq.enumerable.selectmany%28v=vs.100%29.aspx

-saige-
0
 

Author Closing Comment

by:John Bolter
ID: 40513139
Oh of course.

I even wrote

test.Select(n => n.Value).Distinct().Count();

that didn't work. I wasn't even away of SelectMany.

Thank you!
0
 
LVL 86

Expert Comment

by:Mike Tomlinson
ID: 40513231
If you're interested in what those distinct values are, and how many of them there were, then:
        static void Main(string[] args)
        {
            Dictionary<int, List<Single>> test = new Dictionary<int, List<Single>>();

            test.Add(1, new List<Single> { 1f, 2f, 3f, 4f });
            test.Add(15, new List<Single> { 1.1f, 2f });
            test.Add(99, new List<Single> { 1.1f, 1f, 2f });

            int totalNumberOfValues = test.Sum(n => n.Value.Count());  

            var distinctValuesWithCount = test.SelectMany(x => x.Value) // flatten the dictionary values to a single List<Single>
                .GroupBy(x => x) // grouped by each Single in the List
                .Select(group => new // create an anonymous type with the value and number of occurrences of that Single
                {
                    Value = group.Key,
                    Count = group.Count()
                })
                .OrderBy(x => x.Value); // sorted ascending by the Single

            int totalNumberOfDistinctValue = distinctValuesWithCount.Count();

            Console.WriteLine("totalNumberOfDistinctValue = " + totalNumberOfDistinctValue.ToString());
            foreach(var g in distinctValuesWithCount)
            {
                Console.WriteLine("value = " + g.Value.ToString() + ", Count = " + g.Count.ToString());
            }
            Console.ReadLine();
        }

Open in new window


Output:
totalNumberOfDistinctValue = 5
value = 1, Count = 2
value = 1.1, Count = 2
value = 2, Count = 3
value = 3, Count = 1
value = 4, Count = 1

Open in new window

0
 

Author Comment

by:John Bolter
ID: 40514441
Thanks,
0

Featured Post

Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Introduction This article series is supposed to shed some light on the use of IDisposable and objects that inherit from it. In essence, a more apt title for this article would be: using (IDisposable) {}. I’m just not sure how many people would ge…
Performance in games development is paramount: every microsecond counts to be able to do everything in less than 33ms (aiming at 16ms). C# foreach statement is one of the worst performance killers, and here I explain why.
Michael from AdRem Software explains how to view the most utilized and worst performing nodes in your network, by accessing the Top Charts view in NetCrunch network monitor (https://www.adremsoft.com/). Top Charts is a view in which you can set seve…
In this brief tutorial Pawel from AdRem Software explains how you can quickly find out which services are running on your network, or what are the IP addresses of servers responsible for each service. Software used is freeware NetCrunch Tools (https…

726 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question