mikähän mättää. seuraava ohjelma ei vain toimi. lähinnä miksi koodissani ei silmukka pysy?
Tehtävän anto:
Tee ohjelma, joka laskee tietyn ajanjakson aikana tehtyjen työtuntien määrän sekä tulostaa tuntien yhteismäärän, keskimääräisen työpäivän pituuden ja syötetyt tunnit eriteltynä. Ohjelman tulee aluksi kysyä, kuinka monen työpäivän tiedot syötetään (max. 30 päivää). Tämän jälkeen ohjelma kysyy päivittäiset työtunnit.
Vihje:
Ohjelman toteutus onnnistuu helpoimmin käyttämällä apuna taulukkoa, jonka koko on 30 alkiota.
Ohjelma kirjoitetaan luokkaan, jonka nimi on ´Tunnit´.
Esimerkkitulostus
Ohjelma laskee yhteen haluamasi ajanjakson aikana
tehdyt työtunnit sekä keskimääräisen työpäivän pituuden.
Kuinka monta päivää:5
Anna 1. päivän työtunnit:7.4
Anna 2. päivän työtunnit:4.8
Anna 3. päivän työtunnit:7.5
Anna 4. päivän työtunnit:8.6
Anna 5. päivän työtunnit:6.7
Tehdyt työtunnit yhteensä: 35.0
Keskimääräinen työpäivän pituus: 7.0
Syötetyt tunnit: 7.4 4.8 7.5 8.6 6.7
Koodi jonka olen väsännyt:
public class Tunnit
{
public static void main(String[] args)
{
int paivat;
int paivat2 = 1;
int tunnit;
int i;
int tunnit1 = 0;
double kaikki = 0;
int taulukko[] = new int[31];
double keskimaara;
BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
try
{
System.out.print("Ohjelma laskee yhteen haluamasi ajanjakson aikana tehdyt\n");
System.out.print("työtunnit sekä keskimääräisen työpäivän pituuden.\n");
System.out.print("Kuinka monta päivää:");
paivat = Integer.parseInt(in.readLine());
for (i = 1; i < paivat; i )
{
System.out.print("Anna " i ". päivän työtunnit:");
taulukko[i]= Integer.parseInt(in.readLine());
kaikki = tunnit1;
taulukko[i] = tunnit1;
}
System.out.print("Tehdyt työtunnit yhteensä:" kaikki);
keskimaara = ((int)((kaikki / paivat) * 10)) / 10.0;
System.out.print("Keskimääräinen työpäivän pituus:\n" keskimaara);
System.out.print("Syötetyt tunnit:");
for (i = 1; i < paivat; i )
{
System.out.print( taulukko[i]);
}
}
catch(Exception e)
{
System.out.print("virhe!!! ");
}
}
}
Olisiko kellään apuja kyseiseen ongelmaan?
Apuaaa
2
1568
Vastaukset
- Piru_
kaikenlaista vikaa tuntuu olevan.
int taulukko[] = new int[31];
Miksi taulukko on tyyppiä int, kun kerran laitat sinne doubleja? Jokaisesta doublesta häviää desimaalit tuossa.
sitten alustat tunnit1 nollaksi jonka jälkeen
System.out.print("Anna " i ". päivän työtunnit:");
taulukko[i]= Integer.parseInt(in.readLine());
kaikki = tunnit1;
taulukko[i] = tunnit1;
eli luet taulukkoon näppäimistöltä (inttinä taas vaikka sieltä tulee doubleja). Sitten lasket kaikki = kaikki tunnit1 mistä tulee AINA nolla. Sitten sijoitat vielä sen nollan taulukkoon juuri lukemasi tiedon päälle.
Pitäis varmaan olla
tunnit1 = Double.parseDouble(in.readLine());
kaikki = tunnit1;
taulukko[i] = tunnit1;
"
keskimaara = ((int)((kaikki / paivat) * 10)) / 10.0;
"
Keskiarvo lasketaan kaikki / paivat. Kaikki muuttujat vaan doubleiksi niin ei tartte tuollaista 10.0 jakamista. Sitten vielä muunnat tuloksen intiksi, että taas häviää kaikki desimaalit.
lopuksi
System.out.print( taulukko[i]);
turvallisempi ois ehkä
System.out.print("" taulukko[i]);
Koodaisit jollain IDE:llä esim. Eclipse. Sillä voisit ajaa ohjelmaasi Debug-moodissa ja näkisit itse, että mitä siellä muuttujien sisällä oikeasti menee. Säästyy aikaa ja hermoja- Ammattilainen
Käytä markkinoiden parasta kehitystyökalua: JBuilderia, siis sen ilmaista kokeiluversiota, joka riittää erinomaisesti tuollaiseen yksinkertaiseen perus-hommailuun.
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Riikka Purra leikkasi alimmalta tulodesiililtä 15 %
Muistaako kukaan Riikka Purran kovaäänisen vaalilupauksen ennen eduskuntavaaleja? https://yle.fi/a/74-20221152 "THL o3536475Muistele nainen niitä meidän yhteisiä hetkiä
Miltä ne tuntui? Enkö aina huokunut välittämistä, kiintymystä. Eikö sinulla aina ollut hyvä olo kanssani? Minulla ainaki483836Odottavan aika on pitkä, Lindtmanin hallitusta tule jo!
Eilisen perusteella nykyinen hallitus epäonnistui kaikissa vaalilupauksissaan, joten olemme ansainneet uudet eduskuntava11336Riikan vappumiljardin maksavat sairaat, vanhukset ja kuolleiden omaiset
Vappumiljardi, eli Riikan päätös laskea yhteisöveroa kaksi prosenttiyksikköä 18 prosenttiin, vie verotuloja noin miljard31102- 971035
- 52900
- 56866
Naiset ei halua kilttejä miehiä
Näin se vaan on..jos olet ilman tatskoja, et rähjää, sinulla ei ole rikosrekisteriä, olet liian kiltti, et sano pahasti,140862- 41830
Tämä kikka tekee lihapullista entistä maukkaampia - Tämä "ihmeaine" löytyy keittiön kaapista
Lihapullat ja ruskea kastike on arkiruokien kunkku! Paistatko itse lihapullat pannulla vai uunissa? Näin saat ruoasta v9827