Advertisement
elena1234

Truck Tour-C# Advanced

Dec 12th, 2020 (edited)
300
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 2.42 KB | None | 0 0
  1. using System;
  2. using System.Linq;
  3. using System.Collections.Generic;
  4.  
  5. namespace TruckTour
  6. {
  7.     class Program
  8.     {
  9.         static void Main(string[] args)
  10.         {
  11.             int numbersOfPumps = int.Parse(Console.ReadLine());
  12.             var queueForPetrol = new Queue<int>();
  13.             var queueForDistance = new Queue<int>();
  14.             var queueForIndex = new Queue<int>();
  15.             for (int i = 0; i < numbersOfPumps; i++)
  16.             {
  17.                 int[] input = Console.ReadLine().Split().Select(int.Parse).ToArray();
  18.                 int quantityPetrolInThePump = input[0];
  19.                 queueForPetrol.Enqueue(quantityPetrolInThePump);
  20.                 int distanceBetwenTheNext = input[1];
  21.                 queueForDistance.Enqueue(distanceBetwenTheNext);
  22.                 queueForIndex.Enqueue(i);
  23.             }
  24.  
  25.             int amountPetrolInTheTruck = 0;
  26.             int countPassedPump = 0;
  27.             int index = 0;
  28.             while (countPassedPump != numbersOfPumps + 1) // condition to complete the circle
  29.             {
  30.                 int petrol = queueForPetrol.Peek();
  31.                 int distance = queueForDistance.Peek();
  32.                 index = queueForIndex.Peek();
  33.                 amountPetrolInTheTruck += petrol;
  34.                 if (amountPetrolInTheTruck >= distance)
  35.                 {
  36.                     countPassedPump++;
  37.                     MoveFirstElementsToTheLastPositions(queueForPetrol, queueForDistance, queueForIndex, index, petrol, distance);
  38.                     amountPetrolInTheTruck -= distance;
  39.                 }
  40.  
  41.                 else if (amountPetrolInTheTruck < distance)
  42.                 {
  43.                     countPassedPump = 0;
  44.                     amountPetrolInTheTruck = 0;
  45.                     MoveFirstElementsToTheLastPositions(queueForPetrol, queueForDistance, queueForIndex, index, petrol, distance);
  46.                 }
  47.             }
  48.  
  49.             Console.WriteLine(index);
  50.         }
  51.  
  52.  
  53.         private static void MoveFirstElementsToTheLastPositions(Queue<int> queueForPetrol, Queue<int> queueForDistance, Queue<int> queueForIndex, int index, int petrol, int distance)
  54.         {
  55.             queueForDistance.Dequeue();
  56.             queueForPetrol.Dequeue();
  57.             queueForIndex.Dequeue();
  58.             queueForDistance.Enqueue(distance);
  59.             queueForPetrol.Enqueue(petrol);
  60.             queueForIndex.Enqueue(index);
  61.         }
  62.     }
  63. }
  64.  
  65.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement