Napisał Michał w kategorii Bash, Studia, tags: Bash, silnia
Prosty skrypt liczący silnię.
1
2
3
4
5
6
7
8
| #!/bin/bash
j=1
for i in `seq $1`
do
j=$[j*i]
echo -e "$j"
done |
Brak komentarzy »
Tym razem kolejny skrypt do losowania jednak oparty na tablicach dynamicznych. Autorem jest Mariusz.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
| #include <iostream>
#include <time.h>
using namespace std;
main () {
srand(time(NULL));
unsigned int *tab, all, ile;
int j, i;
do {
cout << "Podaj maksymalna granice: ";
cin >> all;
cout << "Podaj liczbe losowanych elementow: ";
cin >> ile;
} while ((ile>all) || (ile==0));
tab = new unsigned int [ile];
for (i=0; i<ile; i++) {
tab[i]=(rand()%all)+1;
for (j=i-1; j>=0; j--) {
if (tab[i]==tab[j]) {
tab[i]=(rand()%all)+1;
j=i;
}
}
}
for (i=0; i<ile; i++)
cout << i << " ma wartosc: " << tab[i] << endl;
delete [] tab;
} |
i jeszcze jedna odmiana od Mariusza, ten kod działa tak, że najpierw zeruje wszystkie liczby z których będziemy losować, nastpenie losuje i o ile to możliwe zamienia 0 na 1 i tak az wylosuje pożądaną liczbę elementów:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
| #include <iostream>
#include <time.h>
using namespace std;
main () {
srand(time(NULL));
unsigned int *tab, all, ile, i;
do {
cout << "Podaj calkowita liczbe elementow: ";
cin >> all;
cout << "Podaj liczbe elementow losowanych: ";
cin >> ile;
} while ((all<ile) || (ile==0));
tab=new unsigned int [all+1];
for (i=0; i<all+1; i++)
tab[i]=0;
i=0;
do {
i=(rand()%all)+1;
if (tab[i]==0) {
tab[i]=1;
ile--;
cout << i << ", ";
}
} while (ile);
delete [] tab;
} |
Brak komentarzy »
Losowanie bez powtórzeń. Definiujemy ilość elementów z pośród, których będziemy wybierać dowolną ilość elementów.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
| #include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
using namespace std;
int main(){
srand(time(NULL));
system("clear");
int i,j,X=0,z;
long int start,stop,czas;
do{
cout<<"Podaj ilosc elementow: ";
cin>>z;
}while((z<=0));
do{
cout<<"Podaj liczbe numerkow do wylosowania =< "<<z<<": ";
cin>>X;
}while((X<=0) || (X>z));
start=time(NULL);
int liczby[X];
cout<<"Losowanie:"<<endl;
for(i=1;i<=X;i++)
{
liczby[i]=((rand()% z)+1);
cout<<"Wylosowano "<<i<<" : "<<liczby[i]<<endl;
for(j=i-1;j>0;j--)
{
if(liczby[i] == liczby[j])
{
liczby[i]=((rand()% z)+1);
cout<<"Wylosowano: "<<liczby[j]<<" - Powtorne losowanie: "<<liczby[i]<<endl;
j=i;
}
}
}
for(i=1;i<=X;i++)
cout<<" "<<liczby[i];
stop=time(NULL);
czas=stop-start;
cout<<endl<<"Losowanie trwalo "<<czas<<" sekund.";
} |
Brak komentarzy »
Bardzo prosty przykład. Losujemy bez powtórzeń 6 liczb z 49. Krótki opis: posiadamy tablice 0-49 (50 elementow), zerujemy całą tablicę liczb (0 oznacza niewylosowaną liczbę). Losujemy i sprawdzamy czy w tablicy z liczbami istanieje nasza wylosowana i czy jest równa zero.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
| #include <iostream>
#include <stdlib.h>
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define X 50
using namespace std;
int main(){
srand(time(NULL));
system("clear");
int i,lotto[X],losuj,element=0;
cout<<"Losowanie elementow:"<<endl;
for(i=1;i<=49;i++)
lotto[i]=0;
do
{
losuj=((rand()% 49)+1);
if(lotto[losuj]==0)
{
lotto[losuj]=1;
element++;
cout<<" "<<losuj;
}
}while((element<6));
} |
Brak komentarzy »