0
#include<iostream>
#include<vector>
#include<algorithm>

using namespace std;
int main()
{
    std::vector<int> v;
    long int a1[1000000];
    string a[1000000];
    for (int i=0; i<100; i++)
        a[i]=" ";
    int n;
    cout << "enter the value of n";
    cin >> n;
    for (int i=0; i<n; i++)
    {
        cin >> a1[i];
        v.push_back(a1[i]);
    }
    sort(v.begin(), v.end());
    char ch[100];
    int i=0;
    do { 
        for(int j=0; j<n; j++)
        {
            ch[j] = v[j] + '0';
            // cout<<ch[j];
        }
        int j=3;
        int k=0;
        for(int l=0; l<n; l++)
        {
            a[i] = a[i] + ch[l];
        }
        cout << a[i] << endl;
        i++;
    }
    while (std::next_permutation(v.begin(), v.end()));
    cout << endl << i;
}

すべての順列を文字列配列に格納したいのですが、> 8!(40320)、つまり9!を格納できません。以降、文字列a [1000000]を宣言している場合 、dev c ++でエラーが表示され、9より大きい文字列配列を具体的に(この文字列コードを別のコードに格納したいので)保存する方法を説明できます。または最大15!

4

2 に答える 2

4

スタックオーバーフロー。

このような要素数に対してスタックが小さすぎます。ヒープを使用する必要があります (を使用operator new)。または単に使用しますstd::vector

たとえば、次のように置き換えることができます。

string a[1000000];

std::vector< std::string > a( 1000000 );

についても同じですlong int

于 2013-02-25T18:15:40.453 に答える
0

定期的にフラッシュするファイルに書き込みます。必要な数をメモリにキャッシュします。

于 2013-02-25T19:32:17.197 に答える