• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Konkatenowanie stringu tyle razy, ile wynika z mnożnika. [tablica]

Hosting forpsi easy 1 pln
0 głosów
786 wizyt
pytanie zadane 17 października 2019 w C# przez pitersooon98 Nowicjusz (200 p.)

Cześć wszystkim! Uczę się języka C#, jestem aktualnie na poziomie pisania własnych metod. Napisałem algorytm, ale przy stringu mnie zblokowało. Już długo nad tym zadanikiem myślę i potrzebuję od was jakiejś wskazówki. Zadanie brzmi następująco:

1. Napisz program, który mnoży elementy tablicy jednowymiarowej przez zadaną liczbę. Mnożenie ma być wykonane w metodzie statycznej przyjmującej jako argumenty tablicę typu int oraz liczbę całkowitą (mnożnik). [CHECK] 

2. Uzupełnij program z zadania o metodę przeładowaną przyjmującą tablicę typu string oraz mnożnik typu int. W tym przypadku metoda ma powielać łańcuch znaków (konkatenować tyle razy, ile wynika z mnożnika). Przykładowo dla tablicy o elementach {"ala", "kot", "dom"} oraz mnożniku 2 program powinien wyświetlić tablicę {"alaala", "kotkot", "domdom"}.

Okej, jeśli mnożnik wynosi "2" to algorytm działa poprawnie, jeśli jest większy to nie. Nie wiem jak to ująć żeby wykonywał się tylu krotnie ile wynosi mnożnik.. :/ 

        static void Mnozenie(int [] tab, int x)
        {
            for (int i = 0; i < tab.Length; i++)
            {
                tab[i] = tab[i] * x;
            }
                      
        }
        static void Mnozenie(string[] tab, int x)
        {
                for (int i = 0; i < tab.Length; i++)
                {
                tab[i] = tab[i] + tab[i];
                }
            
        }
        static void Main(string[] args)
        {
            int[] tab1 = { 2, 10, 3, 5, 12 };
            string[] tab2 = { "ala", "kot", "płot" };
            Console.WriteLine("Podaj mnożnik tablicy");
            int mno = int.Parse(Console.ReadLine());
            Mnozenie(tab1, mno);
            foreach (int x in tab1)
            {
                Console.Write("{0}, ", x);
            }
            Mnozenie(tab2, mno);
            for (int a = 0; a < tab2.Length; a++)
            {
                Console.Write("{0}, ", tab2[a]);
            }
            Console.WriteLine();
            Console.ReadKey();
        }

 

1 odpowiedź

+1 głos
odpowiedź 17 października 2019 przez adrian17 Ekspert (336,700 p.)
wybrane 18 października 2019 przez pitersooon98
 
Najlepsza

Okej, jeśli mnożnik wynosi "2" to algorytm działa poprawnie, jeśli jest większy to nie.

Zauważ, że nigdzie tam nie używasz 'x' ;) Musisz dodać stringa 'x' razy.

komentarz 17 października 2019 przez pitersooon98 Nowicjusz (200 p.)
Wiem, że muszę dodać stringa 'x' razy. Nigdzie go nie używam, bo nie wiem jak. Nie można pomnożyć int ze string. Próbowałem z licznikiem i też mi nie wyszło :/
komentarz 17 października 2019 przez adrian17 Ekspert (336,700 p.)
Robisz pętlę wykonującą się x razy i w każdej iteracji dodajesz kopię stringa.
komentarz 17 października 2019 przez pitersooon98 Nowicjusz (200 p.)
No tak, lecz jest to tablica. Wbrew pozorom nie jest to takie łatwe, bynajmniej dla mnie. Dodatkowo musi to być dla każdego argumentu z tablicy, jak zrobiłem pętle w pętli to wyszedł kosmos. Już wyczerpały mi się pomysły :(
komentarz 17 października 2019 przez adrian17 Ekspert (336,700 p.)

bynajmniej 

przynajmniej.

Ale tak, pętla w pętli. W pętli do tab[i] dodajesz oryginalny string kilka razy i tyle.

Pokaż co masz, to doradzę więcej :)

komentarz 18 października 2019 przez pitersooon98 Nowicjusz (200 p.)
for (int i = 0; i < tab.Length; i++)
            {
                for (int a = 2; a <= x; a++)
                {
                    tab[i] = tab[i] + tab[i];
                }
                
            }

 

komentarz 18 października 2019 przez adrian17 Ekspert (336,700 p.)
Teraz dodajesz tak trochę wykładniczo ;)

x+x => xx, potem xx+xx => xxxx, potem xxxx+xxxx => xxxxxxxx etc.
A za każdym razem powinieneś tylko dodać oryginalny string - więc wystarczy go wrzucić do zmiennej pomocniczej.
komentarz 18 października 2019 przez pitersooon98 Nowicjusz (200 p.)
Ja to widzę tak, np:
T = Ti + Ti
T1= T + Ti
T2 = T1 + Ti
Nie wiem jak to przekształcić do mojego zadania ;/ już mi się kończy cierpliwość..
komentarz 18 października 2019 przez adrian17 Ekspert (336,700 p.)
for (pętla i po tab.Length) {
  temp = tab[i]
  for (pętla do x) {
    tab[i] = tab[i] + temp;
  }
}

Tak pseudokodem.

komentarz 18 października 2019 przez pitersooon98 Nowicjusz (200 p.)
Wszystko śmiga! Jedna deklaracja.. chyba za dużo kombinowałem. Dziękuję Ci za pomoc! :)

Podobne pytania

–2 głosów
1 odpowiedź 316 wizyt
0 głosów
1 odpowiedź 1,738 wizyt
pytanie zadane 9 lutego 2020 w C i C++ przez dario Nowicjusz (200 p.)
–1 głos
0 odpowiedzi 222 wizyt
pytanie zadane 21 czerwca 2018 w C# przez xxkondzioxx15 Obywatel (1,440 p.)

92,092 zapytań

140,753 odpowiedzi

317,719 komentarzy

61,410 pasjonatów

Advent of Code 2023

Top 15 użytkowników

  1. 162p. - nidomika
  2. 160p. - CC PL
  3. 158p. - Łukasz Eckert
  4. 155p. - sefirek
  5. 150p. - Mikbac
  6. 150p. - TheLukaszNs
  7. 78p. - Jarosław Roszyk
  8. 76p. - Fiji404
  9. 75p. - rucin93
  10. 0p. - Vinox
  11. 0p. - s. Dorota Kowalewska
  12. 0p. - kayteeturien
  13. 0p. - IT Vlad
  14. 0p. - the Bielsky
  15. 0p. - Hubert Chęciński
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Akademia Sekuraka 2024 zapewnia dostęp do minimum 15 szkoleń online z bezpieczeństwa IT oraz dostęp także do materiałów z edycji Sekurak Academy z roku 2023!

Przy zakupie możecie skorzystać z kodu: pasja-akademia - użyjcie go w koszyku, a uzyskacie rabat -30% na bilety w wersji "Standard"! Więcej informacji na temat akademii 2024 znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...