• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Wpisywanie polskich znaków do char

0 głosów
80 wizyt
pytanie zadane 10 grudnia 2018 w C i C++ przez BarHorab Nowicjusz (120 p.)

Mam już napisany programik do prostego szyfrowania alfabetu. Lecz nie mogę uporać się z polskimi znakami. Szukałem w sieci, na forach - jest bardzo dużo informacji na temat samego wyświetlania polskich znaków a mi chodzi o ich działanie w tablicy char. Po wpisaniu litery z ogonkiem ą "program przestaje działać". Kiedy za ą podstawię zwykłą literę, otrzymam polski znak, ale w drugą stronę nie działa. Być może sprawa jest banalna i wystarczy nadać odpowiedni parametr char.
 

char szyfr[256];
char a;
int main()
{
setlocale(LC_ALL, "");

    for(int i=1; i<=100; i++)
{
cin.get( a );

szyfr[a] = a;

szyfr['ą'] = 'ę';
szyfr['b'] = 'r';

    cout<<szyfr[a];
}
return 0;
}

 

2 odpowiedzi

+2 głosów
odpowiedź 10 grudnia 2018 przez monika90 Pasjonat (23,620 p.)
edycja 10 grudnia 2018 przez monika90

Za każdym razem kiedy indeksujesz tablicę charem rzutuj go na unsigned char:

szyfr[static_cast<unsigned char>(a)] = a;
 
szyfr[static_cast<unsigned char>('ą')] = 'ę';
szyfr['b'] = 'r'; //tu nie musisz, bo 'b' jest dodatnie
 cout<<szyfr[static_cast<unsigned char>(a)];

 

komentarz 10 grudnia 2018 przez BarHorab Nowicjusz (120 p.)
A nie trzeba dodać jakiejś biblioteki, bo niestety nie działa prawidłowo, chociaż już nie wyrzuca programu?
komentarz 10 grudnia 2018 przez monika90 Pasjonat (23,620 p.)
edycja 10 grudnia 2018 przez monika90

Prawdopodobnie kodowanie w twoim pliku źródłowym to windows-1250, a konsola używa cp-852. Zobacz odpowiedź j23.

To znaczy dodaj te opcje

-fexec-charset=cp852 -finput-charset=cp1250

komentarz 10 grudnia 2018 przez BarHorab Nowicjusz (120 p.)
Code Blocks nie posiada kodowania cp852 :)
komentarz 10 grudnia 2018 przez j23 VIP (105,860 p.)
C::B nie musi posiadać, wystarczy, że g++ będzie ;) IDE może mieć ustawione kodowanie na utf-8, pliki źródłowe też.
+1 głos
odpowiedź 10 grudnia 2018 przez j23 VIP (105,860 p.)

Klasyka. Przy założeniu, że mówimy o Windowsie, to co czytasz ze strumienia, jest w kodowaniu cp852. Literały tekstowe/znakowe w twoim kodzie są w kodowaniu Windows-1250. Jeśli kompilujesz w MinGW, dodaj opcję kompilatora -fexec-charset=cp852.

Podobne pytania

0 głosów
1 odpowiedź 164 wizyt
Porady nie od parady
Zadając pytanie postaraj się o szczegółowe opisanie problemu oraz udostępnienie wszystkich istotnych informacji (kody źródłowe, zrzuty ekranu itp.).Opisanie problemu

65,677 zapytań

112,314 odpowiedzi

237,031 komentarzy

46,654 pasjonatów

Przeglądających: 221
Pasjonatów: 8 Gości: 213

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...