Pereiti prie turinio

C++ Gelezinkelio Stotys


Rekomenduojami pranešimai

Sveiki, paskutiniom dienom inirtingai mokausi programuoti C++ ir norėčiau, kad padėtumėte išspręsti šį uždavinį. Sprendimą kaip ir žinau, bet man atrodo, kad einu per aplinkui, nes ten labai daug if ir else if noriu pamatyt normalų sprendimo būdą. Ačiū už atakymus, tai pat jei atsirastų gerų žmonių, kurie mokyklinį c++ kursą moka labai gerai ir norėtu man pakonsultuoti įvairiausiasi c++ klausimais laisvu laiku pridėkit prie skype an.dvinas. O čia Sąlyga:

====================================================================================================================

Geležinkelio stotys A, B ir C yra n-ajame, m-ajame ir p-ajame geležinkelio ruožo kilometruose. Parašykite

programą, kuri surastų, tarp kurių stočių atstumas yra mažiausias. Stotys nebūtinai įvardytos abėcėlės tvarka,

pavyzdžiui, po stoties A gali sekti stotis C.

Pasitikrinkite. Kai n = 3, m = 8, p = 15, turi būti spausdinama:

Atstumas mažiausias tarp A ir B stočių.

Kai n = 3, m = 9, p = 15, turi būti spausdinama:

Atstumai mažiausi tarp A ir B bei B ir C stočių.

Kai n = 3, m = 15, p = 9, turi būti spausdinama:

Atstumai mažiausi tarp A ir C bei B ir C stočių.

Redagavo xamer
Nuoroda į pranešimą
Dalintis kituose puslapiuose

Nežinau gal padės..

 

#include <iostream>
#include <cmath>
using namespace std;

int main()
{
   int A = 3, B = 15, C = 9;
   bool AB = false, AC = false, BC = false;

   int Min = abs(A - B);
   if(Min > abs(A - C)) Min = abs(A - C);
   if(Min > abs(B - C)) Min = abs(B - C);

   if(Min >= abs(A - B)) {
      AB = true;
      Min = abs(A - B);
   }

   if(Min >= abs(A - C)) {
      AC = true;
      Min = abs(A - C);
   }

   if(Min >= abs(B - C)) {
      BC = true;
      Min = abs(B - C);
   }

   cout << "Atstumai maziausi tarp: ";
   if(AB) cout << "A ir B | ";
   if(AC) cout << "A ir C | ";
   if(BC) cout << "B ir C | ";
}

Redagavo Pattio
Nuoroda į pranešimą
Dalintis kituose puslapiuose
  • po 1 mėnesio...

Aš šitą uždavinį išsprendžiau taip:

 

using namespace std;
int abs(int x);
int main()
{   int n, m, p, sk1, sk2, sk3;

   cout << "Kuriame kilometre yra A stotis? ";
   cin >> n;
   cout << "O B stotis ? " <<endl;
   cin >> m;
   cout << "O C kuriame?" << endl;
   cin >> p;

   sk1= n-m;
   sk1= abs(sk1);
   sk2= n-p;
   sk2= abs(sk2);
   sk3=  m-p;
   sk3= abs(sk3);

   if (sk1 < sk2 && sk1<sk3)

       cout << "Atstumas maziausias tarp A ir B" << endl;

         else if (sk1 == sk3 && sk3 < sk2)

           cout << "Atstumas maziausias tarp A ir B bei B ir C" << endl;

         else if (sk2 == sk3 && sk2 < sk1 )

               cout << "Atstumas maziausias tarp A ir C bei B ir C" << endl;


}

 

Atrodo viskas veikia :)

Nuoroda į pranešimą
Dalintis kituose puslapiuose

Prisijunkite prie diskusijos

Jūs galite rašyti dabar, o registruotis vėliau. Jeigu turite paskyrą, prisijunkite dabar, kad rašytumėte iš savo paskyros.

Svečias
Parašykite atsakymą...

×   Įdėta kaip raiškusis tekstas.   Atkurti formatavimą

  Only 75 emoji are allowed.

×   Nuorodos turinys įdėtas automatiškai.   Rodyti kaip įprastą nuorodą

×   Jūsų anksčiau įrašytas turinys buvo atkurtas.   Išvalyti redaktorių

×   You cannot paste images directly. Upload or insert images from URL.

Įkraunama...
  • Dabar naršo   0 narių

    Nei vienas registruotas narys šiuo metu nežiūri šio puslapio.

  • Prisijunk prie bendruomenės dabar!

    Uždarbis.lt nariai domisi verslo, IT ir asmeninio tobulėjimo temomis, kartu sprendžia problemas, dalinasi žiniomis ir idėjomis, sutinka būsimus verslo partnerius ir dalyvauja gyvuose susitikimuose.

    Užsiregistruok dabar ir galėsi:

    ✔️ Dalyvauti diskusijose;

    ✔️ Kurti naujas temas;

    ✔️ Rašyti atsakymus;

    ✔️ Vertinti kitų žmonių pranešimus;

    ✔️ Susisiekti su bet kuriuo nariu asmeniškai;

    ✔️ Naudotis tamsia dizaino versija;

    ir dar daugiau.

    Registracija trunka ~30 sek. ir yra visiškai nemokama.

  • Naujausios temos

  • Karštos temos

×
×
  • Pasirinkite naujai kuriamo turinio tipą...