Rozdíl v poli bez absolutní hodnoty – Java – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Rozdíl v poli bez absolutní hodnoty – Java – Fórum – Programujte.comRozdíl v poli bez absolutní hodnoty – Java – Fórum – Programujte.com

 

Toto vlákno bylo označeno za vyřešené — příspěvek s řešením.
Noneus0
Návštěvník
30. 1. 2013   #1
-
0
-

Zdravím. Potřeboval bych píchnout s problémem, který jsem tu už jednou řešil. A sice, najít největší rozdíl mezi SOUSEDÍCÍMI prvky v poli, a to bez použití absolutní hodnoty. Díky

int pole[] = {1, 6, 20, 1, 5};
        int max = 0;
        for (int i = 0; i < 5-1; i++) {
            int abs = Math.abs( pole[i] - pole[i+1] );
            if( abs > max) max = abs;

        }
        System.out.println(max);

Nahlásit jako SPAM
IP: 93.153.18.–
KIIV
~ Moderátor
+43
God of flame
30. 1. 2013   #2
-
0
-

bez pouziti Math.abs nebo obecne jakekoliv definice absolutni hodnoty?

int abs = pole[i] - pole[i+1];

if (abs < 0) abs *= -1;

Nahlásit jako SPAM
IP: 62.168.56.–
Program vždy dělá to co naprogramujete, ne to co chcete...
Noneus0
Návštěvník
30. 1. 2013   #3
-
0
-

Nejlépe bez jakékoliv definice absolutní hodnoty. Zkouším nalézt co nejvíce možností.

Nahlásit jako SPAM
IP: 93.153.18.–
Flowy0
Věrný člen
30. 1. 2013   #4
-
0
-

druha mocnina a potom odmocnina

ale aj tu budes potrebovat vylucit nulu

Nahlásit jako SPAM
IP: 78.99.242.–
https://github.com/Flowy
KIIV
~ Moderátor
+43
God of flame
30. 1. 2013   #5
-
0
-

no jak sem psal (jen to upravim aby tam nebyl nazev promenne abs :D)

int promenna = pole[i] - pole[i+1];

if (promenna < 0) { promenna *= -1; }
Nahlásit jako SPAM
IP: 62.168.56.–
Program vždy dělá to co naprogramujete, ne to co chcete...
Noneus0
Návštěvník
6. 2. 2013   #6
-
0
-

postup s následujícím nefunguje:

int promenna = pole[i] - pole[i+1];

if (promenna < 0) { promenna *= -1; }

bylo by něco s jednoduchou matematikou?

Nahlásit jako SPAM
IP: 93.153.18.–
KIIV
~ Moderátor
+43
God of flame
7. 2. 2013   #7
-
0
-

no kdyz nefunguje todle, tak asi jen vymenit za programovaci jazyk, co umi pocitat...

Nahlásit jako SPAM
IP: 94.112.35.–
Program vždy dělá to co naprogramujete, ne to co chcete...
Řešení
RomanZ
~ Anonymní uživatel
272 příspěvků
7. 2. 2013   #8
-
0
-
Vyřešeno Nejlepší odpověď

int pole[] = {1, 6, 20, 1, 5};
int max = 0;
for (int i = 0; i < 5-1; i++) {
   int abs1 = pole[i] - pole[i+1];
   int abs2 = pole[i+1] - pole[i];
   if( abs1 > max) max = abs1;
   if( abs2 > max) max = abs2;
}

Nahlásit jako SPAM
IP: 90.176.60.–
Noneus0
Návštěvník
10. 2. 2013   #9
-
0
-

Díky všem

Nahlásit jako SPAM
IP: 93.153.18.–
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, 18 hostů

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ý