當前位置: 首頁>>代碼示例>>C#>>正文


C# List.Sum方法代碼示例

本文整理匯總了C#中NUnit.Framework.List.Sum方法的典型用法代碼示例。如果您正苦於以下問題:C# List.Sum方法的具體用法?C# List.Sum怎麽用?C# List.Sum使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在NUnit.Framework.List的用法示例。


在下文中一共展示了List.Sum方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: TestFiniteReverseAggregate

        public void TestFiniteReverseAggregate()
        {
            var seq = new List<int> { 1, 2, 3, 4, 5 };

            Assert.That(seq.ReverseAggregate(0, (x, acc) => acc.Value + x), Is.EqualTo(seq.Sum()));
            Assert.That(seq.ReverseAggregate((x1, x2) => x1 + x2.Value), Is.EqualTo(seq.Sum()));
        }
開發者ID:kuzn-ilya,項目名稱:Perseus,代碼行數:7,代碼來源:EnumerableExtensionsTests.cs

示例2: Check_if_data_is_not_retrieved_from_queue

        public void Check_if_data_is_not_retrieved_from_queue()
        {
            const int N = 200;
            const int N_THREADS = 3;

            var sut = new Parallelize(N_THREADS);

            var are = new AutoResetEvent(false);
            var results = new List<int>();
            var threads = new Dictionary<int,bool>();
            Action<IMessage> dequeue = _ => {
                lock(results)
                {
                    if (!threads.ContainsKey(Thread.CurrentThread.ManagedThreadId))
                        threads.Add(Thread.CurrentThread.ManagedThreadId, true);
                    var i = (int) _.Data;
                    results.Add(i);
                    if (results.Count == N) are.Set();
                    Thread.Sleep(i % 20);
                }
            };

            sut.Start();
            for(var i = 1; i<=N; i++)
                sut.Process(new Message("x", i), dequeue);

            Assert.IsTrue(are.WaitOne(4000));
            Assert.AreEqual((N*(N+1)/2), results.Sum());
            Assert.AreEqual(N_THREADS, threads.Count);
        }
開發者ID:kennychou0529,項目名稱:NPantaRhei,代碼行數:30,代碼來源:test_Parallelize.cs

示例3: Download

        public void Download(byte[] data, int bufferSize, DownloadSegmentPositions[] segmentPositionInfos)
        {
            BeforeDownload();

            DownloadStream inputStream = new DownloadStream(data);

            IList<ISegmentDownloadTask> segmentDownloadTasks = new List<ISegmentDownloadTask>(segmentPositionInfos.Length);
            IList<DownloadStream> downloadStreams = new List<DownloadStream>(segmentPositionInfos.Length);
            MemoryStream outputStream = new MemoryStream();
            for (int i = 0; i < segmentPositionInfos.Length; i++)
            {
                DownloadSegmentPositions segmentPosition = segmentPositionInfos[i];
                byte[] dataPart = data.Skip((int) segmentPosition.StartPosition).Take((int)(segmentPosition.EndPosition - segmentPosition.StartPosition + 1)).ToArray();
                DownloadStream downloadStream = new DownloadStream(dataPart);
                segmentDownloadTasks.Add(CreateSegmentDownloadTask(bufferSize, CreateSegmentDownloader(downloadStream, segmentPosition), CreateSegmentWriter(outputStream)));
                downloadStreams.Add(downloadStream);
            }

            SegmentDownloadManager segmentDownloadManager = new SegmentDownloadManager(new SegmentDownloadTaskCollection(segmentDownloadTasks));
            segmentDownloadManager.Start();
            segmentDownloadManager.Finish(true);

            AfterDownload();

            long totalDownloads = downloadStreams.Sum(x => x.TotalDownloads);
            Assert.AreEqual(data.Length, totalDownloads);
            Assert.AreEqual(inputStream.ToArray().Take(data.Length).ToArray(), outputStream.ToArray().Take(data.Length).ToArray());
            Assert.AreEqual(inputStream.ToArray(), outputStream.ToArray());
        }
開發者ID:AccessMartinD,項目名稱:Labo.DownloadManager,代碼行數:29,代碼來源:BaseSegmentDownloadManagerTestFixture.cs

示例4: FindPandigitalProducts

        public void FindPandigitalProducts()
        {
            var products = new List<int>();

            // Highest pandigital standalone number = 987654321
            // Square root of this is 31426
            //var limit = (int) Math.Pow(10, 9);

            // Most lopsided calc would be single digit * 4 digit => 4/5 digit product

            for (int a = 1; a < 10000; ++a)
            {
                for (int b = (a + 1); b < 10000; ++b)
                {
                    var product = a * b;
                    if (product < 1000) continue; // Not going to have enough digits between a, b and product
                    if (product > 99999) break; // Too many digits

                    if (products.Contains(product)) continue;

                    var isPandigital = IsPandigital(a, b, product);
                    if (isPandigital)
                        products.Add(product);
                }
            }

            var sum = products.Sum();
            Console.WriteLine("Sum: {0}", sum);
            foreach (var product in products)
            {
                Console.WriteLine("  {0}", product);
            }

            sum.Should().Be(45228);
        }
開發者ID:kajones,項目名稱:Puzzles,代碼行數:35,代碼來源:Problem_0032_PandigitalProducts.cs

示例5: FindAmicableNumbersUnderTenThousand

        public void FindAmicableNumbersUnderTenThousand()
        {
            const long limit = 10000;

            var list = new List<long>();

            for (long l = 1; l < limit; ++l)
            {
                if (list.Contains(l)) continue;

                var amicable = GetAmicablePair(l);
                if (amicable != 0 && amicable < limit)
                {
                    list.Add(l);

                    if (!list.Contains(amicable)) list.Add(amicable);
                }
            }

            foreach (var l in list)
            {
                Console.WriteLine(l);
            }

            var result = list.Sum();
            Console.WriteLine("Sum of amicable numbers is: {0}", result);

            result.Should().Be(31626);
        }
開發者ID:kajones,項目名稱:Puzzles,代碼行數:29,代碼來源:Problem_0021_AmicableNumbers.cs

示例6: Check_if_data_is_not_retrieved_from_queue

        public void Check_if_data_is_not_retrieved_from_queue()
        {
            const int N = 200;
            const int N_THREADS = 3;

            var sut = new Parallelize<int>(N_THREADS);

            var are = new AutoResetEvent(false);
            var results = new List<int>();
            var threads = new Dictionary<long,bool>();
            Action<int> dequeue = _ => {
                lock(results)
                {
                    if (!threads.ContainsKey(Thread.CurrentThread.GetHashCode()))
                        threads.Add(Thread.CurrentThread.GetHashCode(), true);
                    results.Add(_);
                    if (results.Count == N) are.Set();
                    Thread.Sleep(_ % 10);
                }
            };

            sut.Start();
            for(var i = 1; i<=N; i++)
                sut.Process(i, dequeue);

            Assert.IsTrue(are.WaitOne(4000));
            Assert.AreEqual((N*(N+1)/2), results.Sum());
            Assert.AreEqual(N_THREADS, threads.Count);
        }
開發者ID:fstandhartinger,項目名稱:NPantaRhei,代碼行數:29,代碼來源:test_Parallelize.cs

示例7: Should38

        public void Should38()
        {
            var times = new List<long>();

            var lines = File.ReadAllLines("C:\\tmp\\badphonenumber-clean.log");
            foreach (var line in lines)
            {
                var stopwatch = new Stopwatch();
                stopwatch.Start();
                var isValidNumber = IsValidNumber(line.Trim());
                stopwatch.Stop();
                if (isValidNumber)
                {
                    Console.WriteLine("{0}", line);
                }
                times.Add(stopwatch.ElapsedMilliseconds);
                Thread.Sleep(TimeSpan.FromMilliseconds(500));
            }

            var average = times.Average();
            var count = times.Count;
            var sum = times.Sum();
            var max = times.Max();
            Console.WriteLine("{0} ms. {1} numbers. {2} sum. {3} max", average, count, sum, max);
        }
開發者ID:lasl321,項目名稱:phone-validation,代碼行數:25,代碼來源:Tests.cs

示例8: Add_method_accepts_unknown_number_of_numbers

        public void Add_method_accepts_unknown_number_of_numbers()
        {
            // Allow the Add method to handle an unknown amount of numbers

            // Arrange
            var randomNumber = new Random().Next(1, 100);
            var numbersList = new List<int>(randomNumber);
            var builder = new StringBuilder();
            for (var index = 0; index < randomNumber; index++)
            {
                var thisNumber = new Random().Next(0, 100);
                numbersList.Add(thisNumber);
                if (builder.Length > 0)
                    builder.Append(",");
                builder.Append(thisNumber);
            }
            var numbers = builder.ToString();
            var expected = numbersList.Sum();

            // Act
            var actual = new Calculator().Add(numbers);

            // Assert
            Assert.That(actual, Is.EqualTo(expected));
        }
開發者ID:kenlefeb,項目名稱:Kata,代碼行數:25,代碼來源:Design_Tests.cs

示例9: FileSizeSumTestManyGBs

        public void FileSizeSumTestManyGBs()
        {
            var list = new List<FileSize>();

            Enumerable.Range(1, 1024 * 1024 * 10).ToList().ForEach(it => list.Add(new FileSize(1, Prefix.Mb)));

            var result = new FileSize(10, Prefix.Tb);

            list.Sum().Should().Be(result);
        }
開發者ID:klym1,項目名稱:Toloka-Archive,代碼行數:10,代碼來源:FileSizeSumTest.cs

示例10: should_sum_values

        public void should_sum_values()
        {
            var nums = new List<int>
                           {
                               5,
                               9,
                               1,
                               10
                           };
            int sum = nums.Sum();

            sum.ShouldBe(25);
        }
開發者ID:RookieOne,項目名稱:Learning,代碼行數:13,代碼來源:sum_tests.cs

示例11: Process_messages_on_different_threads

        public void Process_messages_on_different_threads()
        {
            Console.WriteLine("test thread: {0}", Thread.CurrentThread.GetHashCode());

            var frc = new FlowRuntimeConfiguration();
            frc.AddStream(new Stream(".in", "doParallel**"));
            frc.AddStream(new Stream("doParallel", ".out"));

            var threads = new Dictionary<long, int>();
            frc.AddFunc<int, int>("doParallel",
                                                 x =>
                                                 {
                                                     lock (threads)
                                                     {
                                                         if (
                                                             threads.ContainsKey(
                                                                 Thread.CurrentThread.GetHashCode()))
                                                             threads[Thread.CurrentThread.GetHashCode()] += 1;
                                                         else
                                                             threads.Add(Thread.CurrentThread.GetHashCode(), 1);
                                                     }
                                                     Console.WriteLine("thread {0}: {1}.",
                                                                       Thread.CurrentThread.GetHashCode(), x);
                                                     Thread.Sleep((DateTime.Now.Millisecond % 100 + 1) * 50);
                                                     return x;
                                                 });

            using (var sut = new FlowRuntime(frc))
            {
                var are = new AutoResetEvent(false);
                var results = new List<int>();
                sut.Result += _ =>
                                {
                                    Console.WriteLine("result: {0}.", _.Data);
                                    lock (results)
                                    {
                                        results.Add((int) _.Data);
                                        if (results.Count == 5) are.Set();
                                    }
                                };

                sut.Process(new Message(".in", 1));
                sut.Process(new Message(".in", 2));
                sut.Process(new Message(".in", 3));
                sut.Process(new Message(".in", 4));
                sut.Process(new Message(".in", 5));

                Assert.IsTrue(are.WaitOne(10000), "Processing took too long; not enough numbers received");
                Assert.AreEqual(15, results.Sum(), "Wrong sum; some number got processed twice");
            }
        }
開發者ID:kennychou0529,項目名稱:NPantaRhei,代碼行數:51,代碼來源:test_parallel_processing.cs

示例12: CommandExecuted_event_contains_sequential_entry_ids

        public void CommandExecuted_event_contains_sequential_entry_ids()
        {
            var config = new EngineConfiguration()
                .ForImmutability()
                .ForIsolatedTest();
            var engine = Engine.Create<ImmutableModel>(config);

            var sequence = new List<ulong>();
            engine.CommandExecuted += (s, e) => sequence.Add(e.JournalEntryId);

            for(int i = 1; i <=100; i++) engine.Execute(new AppendNumberCommand(i));
            var sum = engine.Execute(m => m.Numbers().Sum());
            Assert.AreEqual(sum, sequence.Sum(n => (decimal) n));
        }
開發者ID:avgx,項目名稱:OrigoDB,代碼行數:14,代碼來源:EngineEventsTests.cs

示例13: should_be_able_to_specify_property_to_sum

        public void should_be_able_to_specify_property_to_sum()
        {
            var jedi = new List<Jedi>
                           {
                               new Jedi("Yoda").MidichlorianCountIs(1000),
                               new Jedi("Anakin Skywalker").MidichlorianCountIs(3000),
                               new Jedi("Luke Skywalker").MidichlorianCountIs(1500),
                               new Jedi("Obi-wan Kenobi").MidichlorianCountIs(500),
                           };

            int sum = jedi.Sum(j => j.MidichlorianCount);

            sum.ShouldBe(6000);
        }
開發者ID:RookieOne,項目名稱:Learning,代碼行數:14,代碼來源:sum_tests.cs

示例14: GetTestData

        public void 配列をたくさん作って合成()
        {
            var data = GetTestData();
            for (var i = 0; i < 1000; i++) {
                var list = new List<double[]>();
                var spectrums = new double[data.Length][];
                Parallel.For(
                    0,
                    data.Length,
                    j => spectrums[j] = ArrayFactory.ByFuncDouble(GetSingleGoussianFunc(data[j].Pc, data[j].Pr), 4096));

                var array = new double[4096];
                Parallel.For(0, 4096, j => array[j] = list.Sum(a => a[j]));
            }
        }
開發者ID:terasato,項目名稱:Xbrt,代碼行數:15,代碼來源:SynthesizingSpectrumTest.cs

示例15: TestSumAggregate

 public void TestSumAggregate()
 {
     List<int?> l = new List<int?>
     {
         0,
         3,
         null,
         4,
         5
     };
     int? sum = l.Sum();
     int? agg = l.Aggregate((int?)0, (s, x) => s + x);
     Assert.IsFalse(sum == null);
     Assert.IsTrue(agg == null);
 }
開發者ID:jandppw,項目名稱:ppwcode-recovered-from-google-code,代碼行數:15,代碼來源:CollectionExtensionsTest.cs


注:本文中的NUnit.Framework.List.Sum方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。