2009-07-04 88 views
1

我試圖用C++解決項目歐拉Problem 8和問題是找到一個1000位數字中連續5個數字的最大產品。所以我想弄清楚如何使用文件io將數字讀入char數組中,我將稍後轉換爲整數。閱讀作品除了最後一行的最後三分之一外,我得到了奇怪的線條,一個綠色的燈籠符號和一顆心。從文件讀取輸入打印奇怪的符號

alt text

#include "stdafx.h" 
#include <iostream> 
#include <fstream> 

using namespace std; 

int _tmain(int argc, _TCHAR* argv[]) 
{ 

const int maxNum = 1000; 
char buffer[maxNum]; 
char *bufferPointer = buffer; 

ifstream infile; 
infile.open("numberlist.txt"); 

if (!infile) 
{ 
    cerr << "Error: Open file failure" << endl; 
    return -1; 
} 

infile.read(bufferPointer, streamsize(maxNum)); 
infile.close(); 
cout << buffer << endl; 
return 0; 

} 

這是TXT文件包含:

73167176531330624919225119674426574742355349194934 
96983520312774506326239578318016984801869478851843 
85861560789112949495459501737958331952853208805511 
12540698747158523863050715693290963295227443043557 
66896648950445244523161731856403098711121722383113 
62229893423380308135336276614282806444486645238749 
30358907296290491560440772390713810515859307960866 
70172427121883998797908792274921901699720888093776 
65727333001053367881220235421809751254540594752243 
52584907711670556013604839586446706324415722155397 
53697817977846174064955149290862569321978468622482 
83972241375657056057490261407972968652414535100474 
82166370484403199890008895243450658541227588666881 
16427171479924442928230863465674813919123162824586 
17866458359124566529476545682848912883142607690042 
24219022671055626321111109370544217506941658960408 
07198403850962455444362981230987879927244284909188 
84580156166097919133875499200524063689912560717606 
05886116467109405077541002256983155200055935729725 
71636269561882670428252483600823257530420752963450 

編輯:緊接着我張貼了這個問題,我才意識到這個問題可能是閱讀是閱讀的新的事實線,因此陣列不夠大,無法容納這一切。

回答

3

您的代碼存在兩個問題。

首先,它看起來好像沒有考慮maxNum緩衝區大小中的換行符,所以它在文本文件結束之前停止讀取19或38個字符(取決於您是使用Unix樣式還是使用Unix樣式或Windows風格的換行符)。或者相應地增加maxNum的值,或者從文本文件中刪除換行符。其次,由於您使用char數組而不是std :: string來存放緩衝區,因此如果您使用流操作符,它需要以null結尾才能正確顯示。在讀入緩衝區後添加以下行(您還需要將緩衝區大小增加1以考慮多餘字符)。

buffer[maxNum-1] = '\0'; 

備選地,可以使用cout.write()來顯示的已知長度的緩衝區,這不是空終止,如下所示:

cout.write(buffer, maxNum); 
+0

出於某種原因,該文本是長1038個字,我不明白爲什麼。我計算了20行,每行50個字符,並考慮19行新行,這是我無法放下手指的事情的兩倍。 – 2009-07-04 23:31:57

2

那麼,這是不是很地道的C++,你可以,如果你切換到使用的std :: string代替焦炭的

這可能會解決這個問題的一個普通數組得到很好的結果。

這就是數字列表長度超過1000個字符,因此不適合您的緩衝區。

0

我還建議使用C++存儲對象如std::string sstd::vector<char> v

隨着vector<char> v你可以使用istream_iterator<char> ifi(infile)std::copy(ifi, istream_iterator<char>(), back_inserter(v))