Pole ve VBA Excel – Visual Basic – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Pole ve VBA Excel – Visual Basic – Fórum – Programujte.comPole ve VBA Excel – Visual Basic – Fórum – Programujte.com

 

10. 10. 2012   #1
-
0
-

Dobrý večer lámu si hlavu proč mi při podmínce If x < pole(i) Then když kontroluji program pomocí StepInto vrací hodnotu pole stále 0 i když zadám pomocí InputBoxu hodnotu např 15, 20 atd. , nevím co dělám špatně prosém pomozte. Program by měl vypsat všechna zadaná čísla v poli a poté vypsat nejmenší , zde je můj program, děkuji :

Option Explicit
Option Base 1
Sub rada_cisel()
    Dim i As Integer, x As Integer, y As Integer, c As Integer, d As Integer, vys As Single
    Dim ret As String, my_str As String
    Dim pole() As Integer
    i = 0
    c = 0
    d = 0
    ret = ""
    Do
        x = Val(InputBox("zadejte cislo"))
            If x <> 0 Then
        ret = ret + Chr(10) + str(x)
            End If
        i = i + 1
        ReDim Preserve pole(i)
            If x < pole(i) Then
                d = d + 1
                my_str = my_str + str(x)
            End If
        pole(i) = x
    Loop While x <> 0
        MsgBox "Cisla jsou: " + ret + Chr(10) + "a nejmensi cislo je: " + my_str
       
End Sub

Nahlásit jako SPAM
IP: 78.108.157.–
zlz
~ Anonymní uživatel
634 příspěvků
10. 10. 2012   #2
-
0
-

Ta nula je tam asi proto, že v době testu jsi tam ještě nic jiného nevložil.

A všechno ostatní je taky blbě :)

Nahlásit jako SPAM
IP: 80.188.216.–
11. 10. 2012   #3
-
0
-

myslím že nemáš zcela pravdu, protože při prvním projetí je hodnota pole pochopitelně nula, protože hodnota, kterou zadávam z klávesnice se uloží na začátku programu do proměnné x, do pole tuto hodnotu vkládam až před koncem smyčky Do - loop while , proto aby mohlo dojít k porovnání nové hodnoty x se starou, která je uložena v poli(i), problém vydím v ReDim Preserve pole(i), kde mi to haze chybu out of range, ale pritom program jede dál, po každém proběhnutí cyklu je vidět že ta hodnota se přiřadí do pole(i) ale jakmile to dojde k ReDim Preserve pole(i), tak zase se zobrazí hodnota 0, pokud by jste měli nějakou radu jak na to, prosím napište fakt nevím co s tím

Nahlásit jako SPAM
IP: 78.108.157.–
11. 10. 2012   #4
-
0
-

Možná máš pravdu, fakt nevím jak na to, můžeš mi prosimtě poradit pokud víš jak to zprovoznit.

Nahlásit jako SPAM
IP: 78.108.157.–
zlz
~ Anonymní uživatel
634 příspěvků
11. 10. 2012   #5
-
+1
-
Zajímavé

Ten redim se mi zdá být správně. Out of range to nejpíš zobrazuje při krokování při pohledu na pole(i) před tím než se ten redim provede.

V tom ifu máš pole(i), tím testuješ poslední hodnotu, kterou ale přiřadíš až potom. Předchozí hodnota by byla pole(i-1). A musíš pak ještě hlídat, že tam nějaká předchozí hodnota je.

Porovnáním s předchozí hodnotou nezískáš minimum. Co když ta řada bude 3,2,6,5 ?

A nakonec to pole vlastně ani nepotřebuješ. Takhle nějak by to mohlo fungovat:

Sub rada_cisel()
    Dim i As Integer, x As Integer, nejmensi As Integer
    Dim ret As String
    Dim pole() As Integer

    Do
        x = Val(InputBox("zadejte cislo"))
        If x = 0 Then
            Exit Do
        End If

        i = i + 1
        ReDim Preserve pole(i)

        pole(i) = x
        ret = ret + Str(x) + vbNewLine

        If i = 1 Or x < nejmensi Then
            nejmensi = x
        End If
    Loop

    If ret <> "" Then
        MsgBox "Cisla jsou: " + ret + vbNewLine + "a nejmensi cislo je: " + Str(nejmensi)
    End If
End Sub
Nahlásit jako SPAM
IP: 78.156.159.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 10 hostů

Podobná vlákna

Excel VBA SetFocus — založil KECOnaj

Pomoc VBA EXCEL — založil Zbyšek

VBA Excel do .exe — založil Sentir

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý