2013-02-25 2 views
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) i.e 9! если я объявляю string a [1000000], показывающий ошибку в dev C++, может ли кто-нибудь объяснить мне, как хранить его в массиве строк (как я хочу, чтобы этот строковый код в другом коде упрощал) больше 9 ! или до 15!Как хранить больше чисел строк в массиве строк

+0

Вы хотите сохранить строки '15!' В контейнере? Вы уверены, что знаете, насколько это большой объем и сколько он потребует хранения? – Blastfurnace

+0

@Blastfurnace, использующий контейнер, может потребовать большой памяти, я хочу иметь хранилище до 10^15, так как я хочу делать spoj –

+0

Серьезно, выйдите из калькулятора и оцените, сколько ОЗУ/адресного пространства необходимо для более 1,3 трлн 'std :: string' объектов и их содержимого. Если вы делаете это для проблемы spoj, вы, вероятно, пытаетесь сделать нелепое непрактичное решение грубой силы. – Blastfurnace

ответ

4

Переполнение стека.

Стек слишком мал для такого количества элементов. Вам нужно использовать кучу (используя operator new). Или просто используйте std::vector.

Например, вы можете заменить

string a[1000000]; 

с

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

Same для long int.

+0

Я не думаю, что кучи хватит либо на 15! – Daniel

+0

@meh использование контейнера может потребовать большой памяти, я хочу до 10^15 хранения есть ли какая-либо альтернатива –

+0

@ user1670364 - вам нужно провести некоторое исследование. Для этого есть разные техники. Кроме того, это зависит от того, что вы пытаетесь сделать. Это сложная задача. –

0

Пишите в файл, регулярно промывая его. Кэш требуемых в памяти.

Смежные вопросы