2016-11-13 31 views
0

我知道已经有几个关于这个主题的问题回答了,但是他们都不能帮我解决我的问题。请记住,我刚刚开始学习C++编程。C++显示一个字符串(与空格)到一个二维数组?

我正在创建一个程序来读取文本,然后将其显示在N行x M列(由用户输入)中。因此,如果用户写哈利·波特并希望它显示在3×4阵列就应该是这个样子:

H a r r 
y P o t 
t e r 

我已经管理这个代码可以这样做:

cout << "Number of rows: "; 
cin >> nr; 
cout << "Number of columns: "; 
cin >> nc; 
cout << "Type in text: "; 
cin >> text; 

char letters[100][100]; 

for (int row = 0; row < nr; row++) 
{ 
    for (int col = 0; col < nc; col++) 
    { 
     letters[row][col]= text [i]; 
     i++; 
    } 
} 

cout << "Print array: " << endl; 
for (int row = 0; row < nr; row++) 
    { 
     for (int col = 0; col < nc; col++) 
     { 
      cout << letters[row][col]; 
     } 

    cout << "\n"; 
    } 

它工作正常,直到用户写入多个单词。例如,而不是HarryPotter他写道哈利波特(我认为这些词之间的空格是造成问题的原因)。你知道为什么发生这种情况,我该如何解决它?非常感谢你。

+1

如何定义可变文本?如果iif二维数组的总元素大于文本中的字符数,该怎么办? –

+0

你也应该添加null终止到输入文本的末尾 – Raindrop7

+0

我怀疑['std :: getline'](http://en.cppreference.com/w/cpp/string/basic_string/getline)很快会在你的未来。 – WhozCraig

回答

1

问题是operator >>在流中遇到空格字符时停止输入字符串。您应该使用标准功能std::getline

考虑到要显示一个字符串,不需要定义一个数组。该任务可以在不使用数组的情况下完成。

这是一个示范程序。

#include <iostream> 
#include <string> 
#include <limits> 
#include <algorithm> 

int main() 
{ 
    while (true) 
    { 
     std::cout << "Number of rows (0 - exit): "; 

     unsigned int rows; 
     if (not (std::cin >> rows) or (rows == 0)) break; 

     std::cout << "Number of columns (0 - exit): "; 

     unsigned int cols; 
     if (not (std::cin >> cols) or (cols == 0)) break; 

     std::cin.ignore(std::numeric_limits<std::streamsize>::max(), '\n'); 

     std::cout << "Type in text: (Enter - exit): "; 

     std::string text; 
     std::getline(std::cin, text); 
     if (text.empty()) break; 

     std::cout << std::endl; 

     std::string::size_type n = text.size(); 

     n = std::min<std::string::size_type>(n, cols * rows); 

     for (std::string:: size_type i = 0; i < n; i++) 
     { 
      std::cout << text[i]; 

      std::cout << ((i + 1) % cols == 0 ? '\n' : ' '); 
     } 

     std::cout << std::endl; 
    } 

    return 0; 
} 

它的输出可能看起来像

Number of rows (0 - exit): 3 
Number of columns (0 - exit): 4 
Type in text: (Enter - exit): HarryPotter 

H a r r 
y P o t 
t e r 

Number of rows (0 - exit): 2 
Number of columns (0 - exit): 6 
Type in text: (Enter - exit): HarryPotter 

H a r r y P 
o t t e r 

Number of rows (0 - exit): 6 
Number of columns (0 - exit): 2 
Type in text: (Enter - exit): HarryPotter 

H a 
r r 
y P 
o t 
t e 
r 

Number of rows (0 - exit): 4 
Number of columns (0 - exit): 4 
Type in text: (Enter - exit): Antonella Masini 

A n t o 
n e l l 
a M a 
s i n i 

Number of rows (0 - exit): 0 

您可以替代这种说法

if (not (std::cin >> rows) or (rows == 0)) break; 

对于这一说法

if (!(std::cin >> rows) || (rows == 0)) break; 

如果编译器不编译的第一个语句。如果您使用MS VC++,那么在项目的属性中,您应该关闭使用语言扩展(C++,language),并且语句将被编译。

+0

嗨,谢谢你的回应,但是当我把它在我的代码中说,它不能识别变量不... –

+0

@AntonellaMasini你使用什么编译器? –

+0

@AntonellaMasini在任何情况下,你可以只写(if(!(std :: cin >> rows)||(rows == 0))break; –

1

cin会考虑HarryPotter之间的空间作为分隔符,只保存在Harrytext

使用cin.getline,将读取整行,直到按下Enter键。因此,cin.getline(text, sizeof(text)),Harry Potter将保存在text

+0

谢谢你的回答,但是我只需要替换我的“cin >>文本;”与“cin.getline(text,sizeof(text));”; ?因为我试过,它不让我运行程序,因为它说“没有重载函数的实例...匹配参数列表”...... –

+0

您也可以使用'getline(cin,string)'。 – MarcD

+0

你用过的cin.getline(czTmp,row * col)应该没问题。理想情况下应该分配czTmp(row * col)字节。 – Vivek

0

您可以使用字符的动态数组所以它在运行时的大小为行和列的用户输入:

#include <iostream> 
using namespace std; 

int main() 
{ 
    int row, col; 

    cout << "Row: "; 
    cin >> row; 
    cout << "Col: "; 
    cin >> col; 

    char** cText = new char*[row]; 
    for(int i(0); i < row; i++) 
     cText[i] = new char[col]; 

    cin.sync(); // clearing the input buffer 
    cout << "Text: "; 

    char czTmp[100]; 
    cin.getline(czTmp, row * col); // getting user input text which fits to our 2d array of chars 

    int k = 0; 
    for(int i = 0; i < row; i++) 
    { 
     for(int j = 0; j < col; j++) 
     { 
      cText[i][j] = czTmp[k]; // inputting our array 
      k++; 
     } 
    } 

    cText[row - 1][col - 1] = '\0'; // adding a null-terminator because it is not added automatically 

    // printing our array 
    for(int i = 0; i < row; i++) 
    { 
     for(int j(0); j < col; j++) 
      cout << cText[i][j]; 
     cout << endl; 
    } 

    // don't forget to free memory created by new 

    for(int i(0); i < row; i++) 
     delete[] cText[i]; 
    delete[] cText; 
    cout << endl << endl; 
    return 0; 
} 
+0

谢谢你的答案,但是当我使用你的代码时,它在输入列数后崩溃了,你知道这是为什么吗? –

相关问题