9

Reverse

  1. #include <string.h>
  2.  
  3. char *reverse( char *s )
  4. {
  5.     char *p, *q;
  6.  
  7.     for ( p = s, q = s+strlen(s)-1; q > p; p++, q-- ) {
  8.         char c = *p;
  9.         *p = *q;
  10.         *q = c;
  11.     }
  12.     return s;
  13. }
  14.  
  15. #if defined( STANDALONE )
  16.  
  17. #include <iostream>
  18.  
  19. void test( char *s )
  20. {
  21.     // printing s and reverse( s ) in one statement calls reverse first!
  22.     std::cout << "[" << s << "]<->[";
  23.     std::cout << reverse( s ) << "]\n";
  24. }
  25.  
  26. int main() {
  27.     // don't use char* (read-only)
  28.     char s1[] = "123";
  29.     char s2[] = "12";
  30.     char s3[] = "";
  31.  
  32.     test( s1 );
  33.     test( s2 );
  34.     test( s3 );
  35. }
  36.  
  37. #endif

Commentaires

Votre commentaire :
[p] [b] [i] [u] [s] [quote] [pre] [br] [code] [url] [email] strip aide 2000

Entrez un maximum de 2000 caractères.
Améliorez la présentation de votre texte avec les balises de formatage suivantes :
[p]paragraphe[/p], [b]gras[/b], [i]italique[/i], [u]souligné[/u], [s]barré[/s], [quote]citation[/quote], [pre]tel quel[/pre], [br]à la ligne,
[url]http://www.izend.org[/url], [url=http://www.izend.org]site[/url], [email]izend@izend.org[/email], [email=izend@izend.org]izend[/email],
[code]commande[/code], [code=langage]code source en c, java, php, html, javascript, xml, css, sql, bash, dos, make, etc.[/code].