Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- namespace JudgeDSA
- {
- class Program
- {
- static void Main()
- {
- int totalNumbers = int.Parse(Console.ReadLine());
- string[] numbersAsString = Console.ReadLine().Split();
- int[] numbers = new int[totalNumbers];
- Stack<int> jumps = new Stack<int>();
- int maxJumps = 0;
- int maxNumber = int.MinValue;
- for (int i = totalNumbers - 1; i >= 0; i--)
- {
- int currentJumps = 0;
- numbers[i] = int.Parse(numbersAsString[i]);
- int currentNumber = numbers[i];
- if (currentNumber > maxNumber) maxNumber = currentNumber;
- for (int j = i + 1; j < totalNumbers; j++)
- {
- if (numbers[j] > currentNumber)
- {
- currentNumber = numbers[j];
- currentJumps++;
- if (numbers[j] == maxNumber)
- {
- break;
- }
- }
- }
- if (currentJumps > maxJumps)
- {
- maxJumps = currentJumps;
- }
- jumps.Push(currentJumps);
- }
- StringBuilder text = new StringBuilder(1048576);
- text.AppendLine($"{maxJumps}");
- int counter = 0;
- while (counter < totalNumbers)
- {
- text.Append($"{jumps.Pop()} ");
- counter++;
- }
- Console.WriteLine(text);
- }
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement