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 回答