Advertisement
vaakata

FoldAndSum_12.05.2016

May 12th, 2016
88
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 3.11 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace FoldAndSum_12._05._2016
  8. {
  9.     class Program
  10.     {
  11.         static void Main(string[] args)
  12.         {
  13.             int[] numbs = Console.ReadLine().Split(' ').Select(int.Parse).ToArray();
  14.  
  15.             int k = numbs.Length / 4; // example: if numbs.Length = 8 => k = 2;            
  16.             int[] arrStartEnd = new int[2 * k]; //if numbs.Length = 8 => []arrStartEnd.Length = 4;
  17.             int[] arrMiddle = new int[2 * k]; // the middle items of []numbs
  18.             int[] arrSum = new int[2 * k];            
  19.  
  20.             ArrayEnd(numbs, arrStartEnd, k);
  21.             ArrayStart(numbs, arrStartEnd, k);
  22.             ArrayMiddle(numbs, arrMiddle, k);
  23.             ArraySummation(arrStartEnd, arrMiddle, arrSum, k);            
  24.            
  25.            Console.WriteLine(string.Join(" ", arrSum));      
  26.         }
  27.  
  28.         static int[] ArrayEnd(int[] numbs, int[] arrStartEnd, int k) // this method saves reversed nums LAST items in arrStartEnd
  29.         {
  30.             int[] arrTemp = new int[k];
  31.  
  32.             for (int i = 0; i < k; i++)
  33.             {
  34.                 arrTemp[i] = numbs[(3 * k) + i];
  35.             }
  36.  
  37.             for (int iRev = 0; iRev < k - 1; iRev++) // reverse of []arrTemp
  38.             {
  39.                 int old = arrTemp[iRev];
  40.                 arrTemp[iRev] = arrTemp[k - 1 - iRev];
  41.                 arrTemp[k - 1 - iRev] = old;
  42.             }
  43.  
  44.             for (int iSave = 0; iSave < k; iSave++) // saving reversed []arrTmp values in []arrStartEnd.
  45.             {
  46.                 arrStartEnd[k + iSave] = arrTemp[iSave];
  47.             }
  48.                 return arrStartEnd;            
  49.         }
  50.  
  51.         static int[] ArrayStart(int[] numbs, int[] arrStartEnd, int k) // this method saves reversed nums FIRST items in arrStartEnd
  52.         {
  53.             int[] arrTemp = new int[k];
  54.            
  55.             for (int i = 0; i < k; i++)
  56.             {
  57.                 arrTemp[i] = numbs[i];
  58.             }          
  59.  
  60.             for (int iRev = 0; iRev < k - 1; iRev++) // reverse of []arrTemp
  61.             {
  62.                 int old = arrTemp[iRev];
  63.                 arrTemp[iRev] = arrTemp[k - 1 - iRev];
  64.                 arrTemp[k - 1 - iRev] = old;
  65.             }
  66.  
  67.             for (int iSave = 0; iSave < k; iSave++) // saving reversed []arrTmp values in []arrStartEnd.
  68.             {
  69.                 arrStartEnd[iSave] = arrTemp[iSave];
  70.             }
  71.             return arrStartEnd;
  72.         }
  73.  
  74.         static int[] ArrayMiddle(int[] numbs, int[] arrMiddle, int k)
  75.         {
  76.             for (int iMiddle = k; iMiddle < 3 * k; iMiddle++)
  77.             {
  78.                 arrMiddle[iMiddle - k] = numbs[iMiddle];
  79.             }
  80.             return arrMiddle;
  81.         }
  82.  
  83.         static int[] ArraySummation(int[] arrStartEnd, int[] arrMiddle, int[] arrSum, int k)
  84.         {
  85.             for (int iSum = 0; iSum < 2 * k; iSum++)
  86.             {
  87.                 arrSum[iSum] = arrStartEnd[iSum] + arrMiddle[iSum];
  88.             }
  89.             return arrSum;
  90.         }
  91.  
  92.     }
  93. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement