hexHack Temat założony przez niniejszego użytkownika |
Problem z losowaniem liczb » 2014-05-01 17:33:24 Witam, Mam problem z programem, który ma losować dowolne znaki do tablicy, a następnie zapisać je do pliku *txt. Program losuje 10 dowolnych znaków, jednak przy każdym kolejnym wykonaniu pętli te znaki są takie same. np jak mam: char a[ n ][ 10 ]; a[ 0 ][ * ] = keIe84oeKe a[ 1 ][ * ] = keIe84oeKe ... a[ n ][ * ] = keIe84oeKe Program sprawdza, czy jakiś kod* się nie powtarza, a że każdy kolejny kod est taki sam, to program nigdy się nie kończy. *kod jako każde 10 znaków 2-wymiarowej tablicy a Wklejam fragment pseudokodu: srand(( int ) time( NULL ) ); char tab1[ 59 ] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'w', 'x', 'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9' };
char a[ 10000 ][ 10 ]; int k; for( int j = 0; j < 10000; j++ ) { for( int i = 0; i < 10; i++ ) { k = rand() % 58 + 0; a[ j ][ i ] = tab1[ k ]; } for( int l = 0; l < 10000; l++ ) { for( int m = 0; m < j; m++ ) { if( a[ l ][ 0 ] == a[ m ][ 0 ] && a[ l ][ 1 ] == a[ m ][ 1 ] && a[ l ][ 2 ] == a[ m ][ 2 ] && a[ l ][ 3 ] == a[ m ][ 3 ] && a[ l ][ 4 ] == a[ m ][ 4 ] && a[ l ][ 5 ] == a[ m ][ 5 ] && a[ l ][ 6 ] == a[ m ][ 6 ] && a[ l ][ 7 ] == a[ m ][ 7 ] && a[ l ][ 8 ] == a[ m ][ 8 ] && a[ l ][ 9 ] == a[ m ][ 9 ] ) { j--; break; } } } } for( int j = 0; j < 10000; j++ ) { for( int r = 0; r < 10; r++ ) { wygenerowany_kod2 << a[ j ][ r ]; } wygenerowany_kod2 << endl; } |
|
pekfos |
» 2014-05-01 17:52:24 Wklejam fragment pseudokodu: |
Czego..? U mnie ten Twój 'pseudokod' działa jako kod C++.. #include <iostream> #include <fstream> #include <cstdlib> #include <ctime>
int main() { std::ofstream ofs( "a.txt" ); srand(( int ) time( NULL ) ); char tab1[ 59 ] = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'W', 'X', 'Y', 'Z', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'w', 'x', 'y', 'z', '1', '2', '3', '4', '5', '6', '7', '8', '9' }; char a[ 100 ][ 10 ]; int k; for( int j = 0; j < 100; j++ ) { for( int i = 0; i < 10; i++ ) { k = rand() % 58 + 0; a[ j ][ i ] = tab1[ k ]; } for( int l = 0; l < 100; l++ ) { for( int m = 0; m < j; m++ ) { if( a[ l ][ 0 ] == a[ m ][ 0 ] && a[ l ][ 1 ] == a[ m ][ 1 ] && a[ l ][ 2 ] == a[ m ][ 2 ] && a[ l ][ 3 ] == a[ m ][ 3 ] && a[ l ][ 4 ] == a[ m ][ 4 ] && a[ l ][ 5 ] == a[ m ][ 5 ] && a[ l ][ 6 ] == a[ m ][ 6 ] && a[ l ][ 7 ] == a[ m ][ 7 ] && a[ l ][ 8 ] == a[ m ][ 8 ] && a[ l ][ 9 ] == a[ m ][ 9 ] ) { break; } } } } for( int j = 0; j < 100; j++ ) { for( int r = 0; r < 10; r++ ) { ofs << a[ j ][ r ]; } ofs << std::endl; } } |
|
hexHack Temat założony przez niniejszego użytkownika |
» 2014-05-01 18:10:33 A już wiem co zrobiłem źle. Dodałem bibliotekę <time> zamiast <ctime> a szkam błędu w kodzie ;) Dzięki za pomoc! |
|
hexHack Temat założony przez niniejszego użytkownika |
» 2014-05-01 18:42:08 tylko jeszcze takie pytanie: w kodzie usunąłeś linijkę: j--; Czy otrzymany kod nie będzie się powtarzać( czy istnieje możliwość powtórzenia się 10-znakowego kodu?) |
|
pekfos |
» 2014-05-01 18:44:17 Może się powtarzać. A w ten sposób nie wylosujesz 58. |
|
hexHack Temat założony przez niniejszego użytkownika |
» 2014-05-01 18:45:39 To jak mogę uniknąć powtórzeń? |
|
pekfos |
» 2014-05-01 18:56:09 Np tak jak zrobiłeś. Wywaliłem, bo to było potwornie wolne (a potem zmniejszyłem ilość do 100 i tak już zostało) |
|
hexHack Temat założony przez niniejszego użytkownika |
» 2014-05-01 18:59:55 ok, mam: //for( int l = 0; l < 10000; l++ ) { //to bylo zbedne for( int m = 0; m < j; m++ ) { if(m==j) break; if( a[ j ][ 0 ] == a[ m ][ 0 ] && a[ j ][ 1 ] == a[ m ][ 1 ] && a[ j ][ 2 ] == a[ m ][ 2 ] && a[ j ][ 3 ] == a[ m ][ 3 ] && a[ j ][ 4 ] == a[ m ][ 4 ] && a[ j ][ 5 ] == a[ m ][ 5 ] && a[ j ][ 6 ] == a[ m ][ 6 ] && a[ j ][ 7 ] == a[ m ][ 7 ] && a[ j ][ 8 ] == a[ m ][ 8 ] && a[ j ][ 9 ] == a[ m ][ 9 ] ) { //tutaj zmienilem l na j break; } } //}
i program dziala 10000 razy szybciej :) Dziękuję za pomoc, temat zamykam |
|
« 1 » |