Ir para o conteúdo
Joao brandao

Out put C++ duvida

Mensagens Recomendadas

Joao brandao

Boas pessoal, tenho aqui uma duvida muito simples em c++, eu fiz o programa que estao a ver em baixo e gostaria de imprimir cada carácter em uma linha diferente. Em C usa se o "\n" mas em C eu sei que é a beira da declaraçao da variavel ao imprimir(um exemplo muito simples é: printf("%s\n",c) ).

A minha duvida era saber como imprimir linha a linha os caracteres.

Cumprimentos, Joao Brandao

#include <cstdlib>
#include <iostream>

using namespace std;

int main(int argc, char *argv[])
{
    char c[20];
    int i;
    cin.getline(c,20);
  for(i=0;i<strlen(c);i++)
  {
    cout<<c[i];
  }
    system("PAUSE");
    return EXIT_SUCCESS;
}

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pmg

Imprime um '\n' :P

Era assim que eu faria, mas nao sou um conhecedor de C++.

    std::cout << c[i] << '\n';


What have you tried?

Não respondo a dúvidas por PM

A minha bola de cristal está para compor; deve ficar pronta para a semana.

Torna os teus tópicos mais atractivos e legíveis usando a tag CODE para colorir o código!

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
RiKoNnEcT

Comentei a alteração :P

#include <cstdlib>
#include <iostream>

using namespace std;

int main(int argc, char *argv[])
{
    char c[20];
    int i;
    cin.getline(c,20);
  for(i=0;i<strlen(c);i++)
  {
    cout<<c[i]<<endl; //Basta meteres aqui o "endl"
  }
    system("PAUSE");
    return EXIT_SUCCESS;
}

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
kurayama

Duas pequenas correcções, tenta evitar strings de C, usa std::string em vez de char[].

E calcula o tamanho da string só uma vez, como meteste na condição do 'for' calculas o tamanho por cada iteração.

Tens aqui uma versão mais C++(11)  :P

#include <string>
#include <iostream>

int main(int argc, char *argv[])
{
  std::string s;
  std::getline(std::cin, s);

  for(char c : s)
    std::cout << c << std::endl;

  return 0;
}

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

Duas pequenas correcções, tenta evitar strings de C, usa std::string em vez de char[].

E calcula o tamanho da string só uma vez, como meteste na condição do 'for' calculas o tamanho por cada iteração.

Tens aqui uma versão mais C++(11)  :P

#include <string>
#include <iostream>

int main(int argc, char *argv[])
{
  std::string s;
  std::getline(std::cin, s);

  for(char c : s)
    std::cout << c << std::endl;

  return 0;
}

que for é esse????

A solução "melhor" no standart de STD é utilizar os iteratores que seria assim:

#include <string>
#include <iostream>

int main()
{
  std::string s;
  std::getline(std::cin, s);
/*
  for(int i=0;i < s.size();i++)
    std::cout << s[i] << std::endl;
*/

   
    for(std::string::iterator it=s.begin();it!=s.end();++it)
        std::cout<< *it <<std::endl;
  
}


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

desconhecia completamente isso, é que não está a compilar, tenho a versão 4.4.1 do MinGW e não está a compilar, até meti "-std=c++0x" mesmo assim dá erro


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
pikax

pois instalei o MinGW 4.6 e funciona, ignorancia minha no post anterior, sempre aprender coisas novas


Por muito mais que que estude só aprendo uma coisa, que ainda tenho muita coisa para aprender.

A beleza de um código está em decompor problemas complexos em pequenos blocos simples.

"learn how to do it manually first, then use the wizzy tool to save time."

"Kill the baby, don't be afraid of starting all over again. Fail soon, learn fast."

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites
kurayama

Por acaso não tinha testado com gcc, já troquei por clang à uns tempos.

Se usares iteradores, a melhor maneira no standard (C++11 é o standard actual) é usar non-member begin e end.

#include <string>
#include <iostream>

int main()
{
  std::string s;
  std::getline(std::cin, s);

  for(auto it = std::begin(s); it != std::end(s); ++it)
    std::cout<< *it <<std::endl;
}

Partilhar esta mensagem


Ligação para a mensagem
Partilhar noutros sites

Crie uma conta ou ligue-se para comentar

Só membros podem comentar

Criar nova conta

Registe para ter uma conta na nossa comunidade. É fácil!

Registar nova conta

Entra

Já tem conta? Inicie sessão aqui.

Entrar Agora

×

Aviso Sobre Cookies

Ao usar este site você aceita os nossos Termos de Uso e Política de Privacidade. Este site usa cookies para disponibilizar funcionalidades personalizadas. Para mais informações visite esta página.