Vítejte na Elektro Bastlírn?
Nuke - Elektro Bastlirna
  Vytvořit účet Hlavní · Fórum · DDump · Profil · Zprávy · Hledat na fóru · Příspěvky na provoz EB

Vlákno na téma KORONAVIRUS - nutná registrace


Nuke - Elektro Bastlirna: Diskuzní fórum

 FAQFAQ   HledatHledat   Uživatelské skupinyUživatelské skupiny   ProfilProfil   Soukromé zprávySoukromé zprávy   PřihlášeníPřihlášení 

[C] Převod římských čísel na arabské

 
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů
Zobrazit předchozí téma :: Zobrazit následující téma  
Autor Zpráva
Velous



Založen: Mar 12, 2010
Příspěvky: 99

PříspěvekZaslal: út prosinec 11 2012, 18:19    Předmět: [C] Převod římských čísel na arabské Citovat

Zdar, vytvořil jsem program v jazyku C na převod římských čísel na arabské. Ale nefunguje mi odečítání menšího čísla od většího například XL tj. 40, mi program počítá jako LX, tj. 60. Jak mám zapsat, aby program rozlišoval pořadí písmen římských číslic a počítal správně? Díky moc za radu.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
Hill
Administrátor


Založen: Sep 10, 2004
Příspěvky: 19637
Bydliště: Jičín, Český ráj

PříspěvekZaslal: út prosinec 11 2012, 18:43    Předmět: Citovat

Princip je v tom, že se čísla sčítají jen v případě, že za nižší číslicí nenásleduje vyšší.
Když je nižší římská číslovka před vyšší, tak se hodnota té nižší odečítá.
Teď si to přelož do céčka.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
mtajovsky



Založen: Sep 19, 2007
Příspěvky: 3698
Bydliště: Praha

PříspěvekZaslal: út prosinec 11 2012, 20:45    Předmět: Citovat

http://www.cplusplus.com/forum/general/27629/

a mnoho daších odkazů k poučení na Google, heslo

romanian numbers converter in C
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Odeslat e-mail
Velous



Založen: Mar 12, 2010
Příspěvky: 99

PříspěvekZaslal: st prosinec 12 2012, 20:10    Předmět: Citovat

Stále mi to nejde. Půlka kódu, která převádí arabské číslice na římské funguje. U této druhé půlky mi zbývá dořešit to odčítání. O něco jsem jsem pokusil, ale nejde to.

Naposledy upravil Velous dne čt prosinec 13 2012, 16:52, celkově upraveno 1 krát.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
Panda38



Založen: Nov 21, 2012
Příspěvky: 718
Bydliště: Most, Praha, Lanžhot

PříspěvekZaslal: st prosinec 12 2012, 21:20    Předmět: Citovat

No ale tam porovnáváš mezi sebou písmena, tedy ASCII hodnoty znaků, a ta nemají stejné pořadí jako jejich číselné hodnoty. Smile

Jestli to chceš dělat tímto způsobem, tak si nejdříve převeď písmena na čísla do pomocné tabulky a ta pak už můžeš takto porovnávat.

Např.:
kód:
   short cislo2[255];
   while(cislo[a] != '\0')
   {
      switch (cislo[a])
      {
      case 'i':
      case 'I': cislo2[a] = 1; break;
      case 'v':
      case 'V': cislo2[a] = 5; break;
      case 'x':
      case 'X': cislo2[a] = 10; break;
      case 'l':
      case 'L': cislo2[a] = 50; break;
      case 'c':
      case 'C': cislo2[a] = 100; break;
      case 'd':
      case 'D': cislo2[a] = 500; break;
      case 'm':
      case 'M': cislo2[a] = 1000; break;
      default:
         printf("Zadany text %s neni rimske cislo.\n", cislo);
         indikace = 1;
      }
      if (indikace) break;
      a++;
   }
   cislo2[a] = 0;

   if (!indikace)
   {
      a = 0;
      while(cislo2[a] != 0)
      { ....

Nebo použít funkci, která převede jeden římský znak na číslo a používat tuto funkci jak ve výpočtu, tak v porovnání 2 znaků.
kód:
short RimskeCislo(char znak)
{
   switch (znak)
   {
   case 'i':
   case 'I': return 1;
   case 'v':
   case 'V': return 5;
   case 'x':
   case 'X': return 10;
   case 'l':
   case 'L': return 50;
   case 'c':
   case 'C': return 100;
   case 'd':
   case 'D': return 500;
   case 'm':
   case 'M': return 1000;
   }
   return 0;
}
.....
   while(cislo[a] != '\0')
   {
      if (RimskeCislo(cislo[a]) == 0)
      {
         indikace = 1;
         printf("Zadany text %s neni rimske cislo.\n", cislo);
         break;
      }

      if (RimskeCislo(cislo[a]) < RimskeCislo(cislo[a+1]))
         b -= RimskeCislo(cislo[a]);
      else
         b += RimskeCislo(cislo[a]);
      a++;
   }
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
mtajovsky



Založen: Sep 19, 2007
Příspěvky: 3698
Bydliště: Praha

PříspěvekZaslal: st prosinec 12 2012, 21:42    Předmět: Citovat

Jinak - na programování existuje specializované fórum, konkrétně pro C/C++:
http://www.builder.cz/cz/forum/1277427/obecna-diskuse/
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Odeslat e-mail
piitr



Založen: Oct 19, 2007
Příspěvky: 1003

PříspěvekZaslal: čt prosinec 13 2012, 8:18    Předmět: Citovat

Takhle mi to docela funguje:
kód:
#include <stdio.h>
#include <stdlib.h>

static int hodnotaCislice(char znak)
{
   switch( znak )
   {
   case 'i':
   case 'I':
      return 1;
      
   case 'v':
   case 'V':
      return 5;
      
   case 'x':
   case 'X':
      return 10;
      
   case 'l':
   case 'L':
      return 50;
      
   case 'c':
   case 'C':
      return 100;
      
   case 'd':
   case 'D':
      return 500;
      
   case 'm':
   case 'M':
      return 1000;
      
   default:
      fprintf(stderr, "Znak '%c' neni rimska cislice.\n", znak);
      exit(1);
      return 0;
   }
}

static int hodnotaCisla(const char *text)
{
   int aktualni;
   int posledni;
   int ostatni;
   
   posledni = ostatni = 0;
   for ( ; *text; text++ )
   {
      aktualni = hodnotaCislice(*text);
      
      if ( posledni && posledni < aktualni )
      {
         ostatni += aktualni - posledni;
         posledni = 0;
      }
      else
      {
         ostatni += posledni;
         posledni = aktualni;
      }
   }
   
   return ostatni + posledni;
}

int main(int argc, const char **argv)
{
   if ( argc != 2 )
   {
      fprintf(stderr, "Jako parametr zadej rimske cislo.\n");
      exit(1);
   }
   
   printf("Hodnota: %d\n", hodnotaCisla(argv[1]));
   
   return 0;
}
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu Zobrazit autorovy WWW stránky
Zobrazit příspěvky z předchozích:   
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů Časy uváděny v GMT + 1 hodina
Strana 1 z 1

 
Přejdi na:  
Nemůžete odesílat nové téma do tohoto fóra.
Nemůžete odpovídat na témata v tomto fóru.
Nemůžete upravovat své příspěvky v tomto fóru.
Nemůžete mazat své příspěvky v tomto fóru.
Nemůžete hlasovat v tomto fóru.
Nemůžete připojovat soubory k příspěvkům
Můžete stahovat a prohlížet přiložené soubory

Powered by phpBB © 2001, 2005 phpBB Group
Forums ©
Nuke - Elektro Bastlirna

Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.


PHP-Nuke Copyright © 2005 by Francisco Burzi. This is free software, and you may redistribute it under the GPL. PHP-Nuke comes with absolutely no warranty, for details, see the license.
Čas potřebný ke zpracování stránky 0.16 sekund