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 ConsoleApplication1
- {
- class Program
- {
- static void Main(string[] args)
- {
- // 1 2 3 5
- // 4
- // max sum = 15
- string input = Console.ReadLine();
- int jumps = int.Parse(Console.ReadLine());
- int maxSum = int.MinValue;// za da trugva da mi tursi ot nai-malkoto chislo na int -2 milqrda
- string[] StringNumbers = input.Split(' ');// masiv ot stringove koito da mi splitva po interval
- int[] parsedNumbers = new int[StringNumbers.Length];// za da si napravim masiv ot integeri razdeleni s interval prisloqvame gornqit masiv ot stringove
- parsedNumbers = Array.ConvertAll(StringNumbers, int.Parse);// s tozi metod preobrazuvame string masiv v int masiv moje da se napravi i sus for ciukl
- //for (int i = 0; i < StringNumbers.Length; i++) tova
- // {
- // parsedNumbers[i] = int.Parse(StringNumbers[i]);
- // }//////////////////////////////////////////////// tova e for cukal za preobrazuvane na string masiv v int masiv
- for (int i = 0; i < parsedNumbers.Length; i++)
- {
- int index = i;// tazi promenliva index mi durji inderksa na v for vunshniqt for cikul pravim si promenliva index za da ne smenqme i v for cikula tova mi e na4aloto ot tuk trqbva da pochnem purviqt put po4vame ot 0 index vtoriqt put ot 1
- int currentSum = parsedNumbers[index];// zima stoinostta na chisloto ot purviqt index koito trugvame primer pri index 2 chisloto mi e 3 i nie ot nego trugvame kato na4alna stoinost da natrupvame
- for (int j = 0; j < jumps; j++)
- {
- index += parsedNumbers[index];// za da zadvijim ska4aneto tozi index trqbva da se mesti kolkoto mi e stoinosta kato 4islo pod opredeleniqd index na koito sme
- if (index > parsedNumbers.Length - 1)// ako indeksa mi prehvurli pasedNumbers.length-1 minus 1 e zashtoto lenght mi e 4 a iamme samo 3 indexa 0 1 2 3
- {
- index = index % parsedNumbers.Length;// durji mi indexa v predelite na nashiqt masiv 0 1 2 3 // kato razdelim s % na duljinata na masiva mi vrushta ostatuka i to4no opredeleniqt index
- }
- currentSum += parsedNumbers[index];// tuk natrupvame sumata ot stoinosta na 4isloto pod opredeleniqt index
- }
- if (currentSum > maxSum)// za da namerim nai-golqmata stoinost stavnqvame ako maxSum mi e po malko ot currentSum da vliza v if i da prisloqva stoinostta na currentSum na maxSum
- {
- maxSum = currentSum;// edin ot na4inite za namirane na maksimalnata stoinost na razlichni 4ilovi stoinosti
- }
- // moje i da izpolzvame i tozi metod za namiraneto na nai-golqmoto 4islo maxSum = Math.Max(maxSum, currentSum);
- }
- Console.WriteLine("max sum = {0}", maxSum);
- }
- }
- }
- /////// 2 reshenie s osht edim masiv za sumite uprajnenie na natrupvane stoinosti v masiv koito ni durji sumi/presmetnati elementi/////////////////////////////////////
- // 1 2 3 5
- // 4
- // max sum = 15
- string input = Console.ReadLine();
- int jumps = int.Parse(Console.ReadLine());
- int maxSum = int.MinValue;// za da trugva da mi tursi ot nai-malkoto chislo na int -2 milqrda
- string[] StringNumbers = input.Split(' ');// masiv ot stringove koito da mi splitva po interval
- int[] parsedNumbers = new int[StringNumbers.Length];// za da si napravim masiv ot integeri razdeleni s interval prisloqvame gornqit masiv ot stringove
- int[] sumsarr = new int[parsedNumbers.Length];
- parsedNumbers = Array.ConvertAll(StringNumbers, int.Parse);// s tozi metod preobrazuvame string masiv v int masiv moje da se napravi i sus for ciukl
- //for (int i = 0; i < StringNumbers.Length; i++) tova
- // {
- // parsedNumbers[i] = int.Parse(StringNumbers[i]);
- // }//////////////////////////////////////////////// tova e for cukal za preobrazuvane na string masiv v int masiv
- int hui = 0;
- for (int i = 0; i < parsedNumbers.Length; i++)
- {
- int index = i;// tazi promenliva index mi durji inderksa na v for vunshniqt for cikul pravim si promenliva index za da ne smenqme i v for cikula tova mi e na4aloto ot tuk trqbva da pochnem purviqt put po4vame ot 0 index vtoriqt put ot 1
- int currentSum = parsedNumbers[index];// zima stoinostta na chisloto ot purviqt index koito trugvame primer pri index 2 chisloto mi e 3 i nie ot nego trugvame kato na4alna stoinost da natrupvame
- for (int j = 0; j < jumps; j++)
- {
- index += parsedNumbers[index];// za da zadvijim ska4aneto tozi index trqbva da se mesti kolkoto mi e stoinosta kato 4islo pod opredeleniqd index na koito sme
- if (index > parsedNumbers.Length - 1)// ako indeksa mi prehvurli pasedNumbers.length-1 minus 1 e zashtoto lenght mi e 4 a iamme samo 3 indexa 0 1 2 3
- {
- index = index % parsedNumbers.Length;// durji mi indexa v predelite na nashiqt masiv 0 1 2 3 // kato razdelim s % na duljinata na masiva mi vrushta ostatuka i to4no opredeleniqt index
- }
- currentSum += parsedNumbers[index];// tuk natrupvame sumata ot stoinosta na 4isloto pod opredeleniqt index
- sumsarr[hui] = currentSum;
- }
- hui++;
- }
- for (int i = 0; i < sumsarr.Length; i++)
- {
- if(sumsarr[i] > maxSum)
- {
- maxSum = sumsarr[i];
- }
- }
- Console.WriteLine("max sum = {0}", maxSum);
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement