Пример #1
0
        private static double[] CalculateMeanForEveryN(int[] prefixSums, int n)
        {
            var p = new double[prefixSums.Length - n];

            for (var i = 0; i < p.Length; i++)
            {
                p[i] = PrefixSums.CountTotal(prefixSums, i, i + n - 1) / (double)n;
            }
            return(p);
        }
Пример #2
0
        public static int Solve(int[] mushrooms, int m, int k)
        {
            var n      = mushrooms.Length;
            var result = 0;
            var pref   = PrefixSums.CalculatePrefixSums(mushrooms);

            foreach (var p in Enumerable.Range(0, Math.Min(m, k) + 1))
            {
                var leftPos  = k - p;
                var rightPos = Math.Min(n - 1, Math.Max(k, k + m - 2 * p));
                result = Math.Max(result, PrefixSums.CountTotal(pref, leftPos, rightPos));
            }
            foreach (var p in Enumerable.Range(0, Math.Min(m + 1, n - k)))
            {
                var rightPos = k + p;
                var leftPos  = Math.Max(0, Math.Min(k, k - (m - 2 * p)));
                result = Math.Max(result, PrefixSums.CountTotal(pref, leftPos, rightPos));
            }
            return(result);
        }