Posts Tagged “programowanie”

Efekt z C++, zadanko z programowania. Ramka powiększa się do zadanych wymiaró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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#include <stdlib .h>
#include <stdio .h>
#include <iostream>
#define MAX 128
using namespace std;
 
int gotoxy(int x, int y)
{
	char essq[MAX]={0}; 
	sprintf(essq, "\033[%d;%df", y,x);
	printf("%s", essq);
	return 0;
}
 
void draw(int x1,int y1,int x2,int y2,char z) 
{
	int i;
	for (i=x1; i< =x2; i++) 
	{
		gotoxy(i,y1);
		cout<<z;
		gotoxy(i,y2);
		cout<<z;
	}
	for (i=y1+1; i<y2; i++)
	{
		gotoxy(x1,i);
		cout<<z;
		gotoxy(x2,i);
		cout<<z;
	}
}
 
void boom(int x1,int y1,int x2,int y2,char z) 
{
	int x,y,m=0,n=0;
 
	((x1+x2)%2) ? x=((x1+x2)/2)+1 : x=(x1+x2)/2 ;
	((y1+y2)%2) ? y=((y1+y2)/2)+1 : y=(y1+y2)/2 ;
 
	int i=x,j=y;
 
	do
	{
		system("clear");
		if(i<=x2)
		{
			m++;
			i++;
		}
		if(j<=y2)
		{
			n++;
			j++;
		}
		draw(x-m,y-n,x+m,y+n,z);
		getchar();		
	}while((i<=x2) || (j<=y2));
}
 
int main() 
{
	int x1=10, x2=40, y1=10,y2=40;
	char z='o';
	boom(x1,y1,x2,y2,z);
	cout<<endl;
 
}

Comments Brak komentarzy »

Poniżej kilka różnych funkcji.
1. Funkcja do obliczania pola prostokąta. Jeżeli wartości są ujemne to wyświetlamy błąd.

1
2
3
4
5
float prostokat(float a, float b,bool &error)
{
	((a>0) && (b>0)) ? error=true : error=false;
	return a*b;
}

2. Silnia na 2 sposoby (iteracyjnie i rekurencyjnie)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
unsigned int silnia(unsigned n)
{
	long int i;
	int s=1;
 
	for (i=1;i< =n;i++)
        s=s*i;
	return s;
}
 
unsigned int silnia_r(unsigned n)
{
	int s;
	(n&lt;2) ? s=1 : s=n*silnia_r(n-1);
	return s;
}

Comments 1 komentarz »

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;
}

Comments 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.";
 
}

Comments Brak komentarzy »

(c) 2007 by Michał Terbert