• 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
68 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 (100,440 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 (100,440 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ź 159 wizyt
Porady nie od parady
Zadając pytanie postaraj się o odpowiedni tytuł, kategorię oraz tagi.Tagi

63,239 zapytań

109,483 odpowiedzi

228,714 komentarzy

43,293 pasjonatów

Przeglądających: 280
Pasjonatów: 12 Gości: 268

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.

...