コード例 #1
0
        public void IsSmallWindowCorrectBySortedWay()
        {
            var arrayRepo  = new ArrayRepo();
            var data       = new int[] { 3, 7, 5, 6, 9 };
            var result     = arrayRepo.LocateSmallestWindowBySorted(data);
            var checkLeft  = result.left == 1 ? true : false;
            var checkRight = result.right == 3 ? true : false;

            Assert.IsTrue(checkLeft, "Left Failed");
            Assert.IsTrue(checkRight, "Right Failed");
        }
コード例 #2
0
        public void IsWindowCorrect()
        {
            var arrayRepo  = new ArrayRepo();
            var data       = new int[] { 3, 7, 5, 6, 9 };
            var result     = arrayRepo.Window(data);
            var checkLeft  = result.left == 1 ? true : false;
            var checkRight = result.right == 3 ? true : false;

            Assert.IsTrue(checkLeft, "Left Failed");
            Assert.IsTrue(checkRight, "Right Failed");
        }
コード例 #3
0
        public void CheckSmallerElemntsToRight()
        {
            var arrayRepo     = new ArrayRepo();
            var arr           = new int[] { 3, 4, 9, 6, 1 };
            var desiredResult = new List <int> {
                1, 1, 2, 1, 0
            };

            var result      = arrayRepo.FindNumberOfSmallElementsToTheRght(arr);
            var matchResult = result.SequenceEqual(desiredResult);

            Assert.IsTrue(matchResult, "Failed Desired Result is not what was expected");
        }
コード例 #4
0
        public void CheckMaxSubArraySum()
        {
            var arrayRepo = new ArrayRepo();
            //  var arr = new int[] { 34, -50, 42, 14, -5, 86 };
            var arr = new int[] { -2, -3, 4, -1, -2, 1, 5, -3 };

            var maxSum       = arrayRepo.MaxSubarraySum(arr) == 7?true:false;
            var minSubSum    = arrayRepo.MinSubArraySum(arr) == -5?true:false;
            var wrapArounMax = arrayRepo.MaximumCircularSubArray(arr) == 7?true:false;

            Assert.IsTrue(maxSum, "Finding Max Sub Array Sum Failed");
            Assert.IsTrue(minSubSum, "Finding Min Sub Array Sum Failed");
            Assert.IsTrue(wrapArounMax, "Finding Wrap around Sub Array Sum Failed");
        }
コード例 #5
0
        public void IsProductOfAllIndexValidWithoutDevide()
        {
            var arrayRepo = new ArrayRepo();

            var data = new List <int> {
                1, 2, 3, 4, 5
            };
            var actualResult = new List <int> {
                120, 60, 40, 30, 24
            };

            var result = arrayRepo.GetProductOfArrayWithoutDiv(data);
            var flag   = Enumerable.SequenceEqual(actualResult, result);

            Assert.IsTrue(flag, "Result Validated");
        }