Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7989781
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 4, 20262026-06-04T12:50:35+00:00 2026-06-04T12:50:35+00:00

Lets say I have an enumerable source, that looks like this: IEnumerable<string> source =

  • 0

Lets say I have an enumerable source, that looks like this:

IEnumerable<string> source = new [] { "first", "first", "first", "second" };

I want to be able to construct a LINQ statement that will return this:

"first", "first", "second"

Notice how only one of the firsts is gone. I don’t care which one, because in my case all 3 “first”s are considered equal. I’ve tried source.Except(new [] { "first" }) but that strips all instances out.

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-04T12:50:37+00:00Added an answer on June 4, 2026 at 12:50 pm
    source
      .GroupBy(s => s)
      .SelectMany(g => g.Skip(1).DefaultIfEmpty(g.First()))
    

    For each group, skip the first element of the group and return the rest – unless that would return none… in that case, return the first element of the group.


    source
      .GroupBy(s => s)
      .SelectMany(g => g.Take(1).Concat(g.Skip(2)))
    

    For each group, take the first element, and take from the third element on – always skipping the second element.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

Lets say I have hierarchy like this (This is just a test program. Please
Lets say I have one table called REVIEWS This table has Reviews that customers
Lets say I have this extention method: public static bool HasFive<T>(this IEnumerable<T> subjects) {
Let's say I have the following method: public static int CountNonNullMembers<T>(this IEnumerable<T> enumerable) {
Lets say have this immutable record type: public class Record { public Record(int x,
Lets say I have this code: <?php class hello { var $greeting = hello;
Lets say I have multiple DataGrids throughout my winform app and I want to
Lets say you have strings of this format. January 11th, 111 November 1st, 1101
Lets say we have this interface: public interface ILog { void Add(Message message); }
Lets say we have this interface: interface IVehicle { ... } And some classes

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.