void sortare_insertie(float *v, int n) {
float aux;
int i,j;
for(i=0;i<n;i++)
if(v[i]<v[i-1]) {
aux = v[i];
j=i-1;
while((j>=0) && (v[j]>aux)) {
v[j+1]=v[j];
j=j-1;
}
v[j+1]=aux;
}
}
Showing posts with label subprogram. Show all posts
Showing posts with label subprogram. Show all posts
Sunday, March 27, 2016
Saturday, March 12, 2016
25) Functia Hermite recursiv
#include <stdio.h>
#include <stdlib.h>
long Hermite(int n, int x){
if(n==0) {
return 1;
}
else if(n=1) {
return 2*x;
}
else {
return 2*n*Hermite(n-1,x)-2*(n-1)*Hermite(n-2,x);
}
}
void main(){
int n,x;
long polH;
printf("Gradul polinomului = "); scanf("%d", &n);
printf("x= ", &x); scanf("%d", &x);
polH = Hermite(n,x);
printf("Rezultatul este: %ld", polH);
}
#include <stdlib.h>
long Hermite(int n, int x){
if(n==0) {
return 1;
}
else if(n=1) {
return 2*x;
}
else {
return 2*n*Hermite(n-1,x)-2*(n-1)*Hermite(n-2,x);
}
}
void main(){
int n,x;
long polH;
printf("Gradul polinomului = "); scanf("%d", &n);
printf("x= ", &x); scanf("%d", &x);
polH = Hermite(n,x);
printf("Rezultatul este: %ld", polH);
}
24) Functia Ackermann recursiv
#include <stdio.h>
#include <stdlib.h>
int Ackermann(int m, int n) {
if(m==0) {
return n+1;
}
else if((n=0)&&(m>0)) {
return Ackermann(m-1,1);
}
else if((m>0)&&(n>0)) {
return Ackermann(m-1, Ackermann(m,n-1));
}
}
void main(){
long result;
int m,n;
printf("m: "); scanf("%d", &m);
printf("n: ");scanf("%d", &n);
result=Ackermann(m,n);
printf("Rezultatul functie Ackermann este: %d", result);
}
Sunday, March 6, 2016
22) Ridicarea unei matrice la o putere data
#include <stdio.h>
#include <stdlib.h>
void citireMatrice(int a[20][20], int *n) {
int i,j;
printf("Numarul de linii & coloane: "); scanf("%d", &(*n));
for(i=0;i<*n;i++) {
for(j=0;j<*n;j++) {
printf("a[%d][%d] = ", i,j);
scanf("%d", &a[i][j]);
}
}
}
void afisareMatrice(int a[20][20], int n) {
int i,j;
for(i=0;i<n;i++) {
for(j=0;j<n;j++) {
printf(" %d ", a[i][j]);
}
puts(" ");
}
}
void putereMatrice(int a[20][20], int n, int p) {
// <!--- generarea matricei unitate--->
int i,j,q,k,c[20][20];
int b[20][20];
for(i=0;i<n;i++) {
for(j=0;j<n;j++) {
b[i][j]=(i==j);
}
} // <!--- generarea matricei unitate--->
puts("Afisarea matricei unitate...");
for(i=0;i<n;i++) {
for(j=0;j<n;j++) {
printf(" %d ",b[i][j]);
}
puts(" ");
}
for(q=0;q<p;q++) {
for(i=0;i<n;i++)
for(j=0;j<n;j++) {
c[i][j]=0;
for(k=0;k<n;k++)
c[i][j] = c[i][j]+b[i][k]*a[k][j];
}
for(i=0;i<n;i++)
for(j=0;j<n;j++)
b[i][j]=c[i][j];
}
printf("Afisarea matricea ridicata la puterea %d \n", p);
for(i=0;i<n;i++) {
for(j=0;j<n;j++) {
printf(" %d ",b[i][j]);
}
puts(" ");
}
}
void main(){
int a[20][20];
int i,j,n,p;
citireMatrice(a,&n);
afisareMatrice(a,n);
printf("Puterea este: "); scanf("%d", &p);
putereMatrice(a,n,p);
}
Saturday, January 9, 2016
21) Transformarea unei matrice triunghiulara inferior intr-una triunghiulara superior
//o matrice este triunghiular inferioara daca toate elementele de sub diagonala principala sunt egale cu 0
#include <stdio.h>
#include <stdlib.h>
int k;
int triunghiulara(int a[20][20], int n, int m) {
int i,j, tri=0;
k=1;
for(i=0;i<n;i++) {
for(j=i+1;j<m;j++) {
if(a[i][j]!=0) {
k=0;
}
}
}
if(k!=0){
tri=1;}
return tri;
}
void triunghiularaSuperior(int a[20][20], int n, int m) {
int i,j;
for(i=1;i<n;i++) {
for(j=0;j<i;j++) {
a[i][j] = 0;
}
}
}
int main() {
int a[20][20];
int i,j,n,m, tri=0;
printf("Linii: "); scanf("%d", &n);
printf("Coloane: "); scanf("%d", &m);
for(i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf("a[%d][%d] = ",i,j); scanf("%d", &a[i][j]);
}
}
puts("Afisare matrice... \n");
for(i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf(" %d ", a[i][j]);
}
puts(" ");
}
puts(" ");
tri = triunghiulara(a,n,m);
if(tri==1) {
puts("Matricea este triunghiulara inferior \n -----> Transformare in matrice triunghiulara superior... \n");
triunghiularaSuperior(a, n, m);
puts("Afisare matrice triunghiulara superior & inferior \n");
for(i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf(" %d ", a[i][j]);
}
puts(" ");
}
}
}
20) Verificarea daca o matrice este triunghiular inferioara
//o matrice este triunghiular inferioara daca toate elementele de deasupra diagonalei principale sunt egale cu 0
#include <stdio.h>
#include <stdlib.h>
int k;
int triunghiulara(int a[20][20], int n, int m) {
int i,j, tri=0;
k=1;
for(i=0;i<n;i++) {
for(j=i+1;j<m;j++) {
if(a[i][j]!=0) {
k=0;
}
}
}
if(k!=0){
tri=1;
}
return tri;
}
int main() {
int a[20][20];
int i,j,n,m, tri=0;
printf("Linii: "); scanf("%d", &n);
printf("Coloane: "); scanf("%d", &m);
for(i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf("a[%d][%d] = ",i,j); scanf("%d", &a[i][j]);
}
}
puts("Afisare matrice... \n");
for(i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf(" %d ", a[i][j]);
}
puts(" ");
}
puts(" ");
tri = triunghiulara(a,n,m);
if(tri==1) {
printf("Matricea este triunghiulara inferior. \n");
}
}
Thursday, January 7, 2016
18) Determinarea produsului scalar a doi vectori (subprogram)
Sa se scrie programul care afiseaza produsul scalar a doi vectori folosind un subprogram. Elementele vectorilor vor fi citite de la tastatura.
#include <stdio.h>
#include <stdlib.h>
void scalar(float a[20], float b[20], float *produs, int size) {
int i;
*produs=0;
for(i=0;i<size;i++) {
*produs += a[i]*b[i];
}
}
int main() {
float a[20], b[20], produs;
int i, size;
printf("Dimensiunea vectorilor: "); scanf("%d", &size);
for(i=0;i<size;i++) {
printf("a[%d] = ", i); scanf("%f", &a[i]);
printf("b[%d] = ", i); scanf("%f", &b[i]);
}
scalar(a,b, &produs, size);
printf("prod scalar: %f", produs);
}
17) Determinarea elementului maxim dintr-un vector + aparitiile sale (subprogram)
Sa se scrie programul care afiseaza elementul maxim dintr-un vector precum si pozitiile pe care apare acesta. Vectorul va fi alocat dinamic iar elementele acestuia se vor citi de la tastatura.
#include <stdio.h>
#include <stdlib.h>
void maxim(float *v, float *max, float *aparitii_maxim, int dim) {
int i, k=0;
*max = -99999;
for(i=0;i<dim;i++) {
if(v[i]>*max) {
*max = v[i];
k=1;
aparitii_maxim[0] = i;
}
else if (v[i]==*max) {
aparitii_maxim[k++] = i;
}
}
printf("Elementul maxim este: %6.1f \n", *max);
if(k>0) {
for(i=0;i<k;i++) {
printf("Maximul apare pe pozitiie: %6.0f \n", aparitii_maxim[i]);
}
}
}
int main() {
float *v, element_maxim, aparitii[20];
int i, dim;
printf("Dimensiune vector: "); scanf("%d", &dim);
v = (float*)malloc(dim*sizeof(float));
for(i=0;i<dim;i++) {
printf("v[%d] = ", i); scanf("%f", &v[i]);
}
maxim(v, &element_maxim, aparitii, dim);
}
16) Inmultirea unui a doua matrice (subprogram+alocare dinamica)
Sa se scrie programul care afiseaza rezultatul inmultirii unei matrice A cu o matrice B folosind un subprogram. Elementele ambelor matrice se vor citi de la tastatura.
#include <stdio.h>
#include <stdlib.h>
float **produsF(float a[20][20], float b[20][20], int n, int k) {
float **produs;
int i,j,x;
produs = (float**) malloc(n*sizeof(float));
for(i=0;i<k;i++) {
produs[i] = (float**) malloc(k*sizeof(float));
}
for(i=0;i<n;i++) {
for(j=0;j<k;j++) {
produs[i][j]=0;
for(x=0;x<n;x++) {
produs[i][j] += a[i][x]*b[x][j];
}
}
}
return produs;
}
int main() {
float a[20][20], b[20][20], **c;
int i,j,n,size,k;
printf("Linii A: "); scanf("%d", &n);
printf("Coloane A = Linii B: "); scanf("%d", &size);
printf("Coloane B: "); scanf("%d", &k);
for(i=0;i<n;i++) {
for(j=0;j<size;j++) {
printf("a[%d][%d] = ", i, j); scanf("%f", &a[i][j]);
}
}
for(i=0;i<size;i++) {
for(j=0;j<k;j++) {
printf("b[%d][%d] = ", i, j); scanf("%f", &b[i][j]);
}
}
c = produsF(a, b, n, k);
puts("Matrice rezultat: ");
for(i=0;i<n;i++) {
for(j=0;j<size;j++) {
printf(" %f ", c[i][j]);
}
puts(" ");
}
}
15) Inmultirea a doua matrice (subprogram)
Sa se scrie programul care afiseaza rezultatul inmultirii unei matrice A cu o matrice B folosind un subprogram. Elementele ambelor matrice se vor citi de la tastatura.
#include <stdio.h>
#include <stdlib.h>
void produs(int a[20][20], int b[20][20], int c[20][20], int n, int k) {
int i,j,x;
for(i=0;i<n;i++) {
for(j=0;j<k;j++) {
c[i][j] = 0;
for(x=0;x<n;x++) {
c[i][j] += a[i][x]*b[x][j];
}
}
}
}
int main() {
int a[20][20], b[20][20], c[20][20]; //c = matrice output
int i,j,n,k,size;
printf("Linii A: "); scanf("%d", &n);
printf("Coloane A = Linii B: "); scanf("%d", &size);
printf("Columns B: "); scanf("%d", &k);
for(i=0;i<n;i++) {
for(j=0;j<size;j++) {
printf("a[%d][%d] = ", i,j); scanf("%d", &a[i][j]);
}
}
for(i=0;i<size;i++) {
for(j=0;j<k;j++) {
printf("b[%d][%d] = ", i,j); scanf("%d", &b[i][j]);
}
}
produs(a,b,c,n,k);
for(i=0;i<n;i++) {
for(j=0;j<size;j++) {
printf(" %d ", c[i][j]);
}
printf("\n");
}
}
Wednesday, January 6, 2016
13) Inmultirea unui vector cu o matrice (subprogram+alocare dinamica)
Sa se scrie programul care afiseaza rezultatul inmultirii unui vector cu o matrice folosind un subprogram. Elementele matricei si ale vectorului se vor citi de la tastatura.
#include <stdio.h>
#include <stdlib.h>
void produs(int a[20][20], int b[], int *c, int dim) {
int j,k;
for(j=0;j<dim;j++) {
c[j] = 0;
for(k=0;k<dim;k++) {
c[j] += b[k]*a[k][j];
}
}
}
int main() {
int a[20][20], b[20], *c;
int i,j,n,m;
c = (int*)malloc(m*sizeof(int));
printf("Numar linii: "); scanf("%d", &n);
printf("Numar coloane: "); scanf("%d", &m);
for (i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf("a[%d][%d] =", i,j); scanf("%d", &a[i][j]);
}
}
for(i=0;i<m;i++) {
printf("b[%d] =", i); scanf("%d", &b[i]);
}
produs(a, b, c, m);
puts("Vectorul rezultat: ");
for(i=0;i<m;i++) {
printf("c[%d] = %d \n",i,c[i]);
}
free(c);
}
12) Inmultirea unui vector cu o matrice (subprogram)
Sa se scrie programul care afiseaza rezultatul inmultirii unui vector cu o matrice folosind un subprogram. Elementele matricei si ale vectorului se vor citi de la tastatura.
#include <stdio.h>
#include <stdlib.h>
void produs(int a[20][20], int b[20], int dim, int c[20]) {
int j,k;
for(j=0;j<dim;j++) {
c[j] = 0;
for(k=0;k<dim;k++) {
c[j] = c[j]+b[k]*a[k][j];
}
}
}
int main() {
int a[20][20], b[20], c[20];
int i,j,n,m,k;
printf("Rows: "); scanf("%d", &n);
printf("Columns: "); scanf("%d", &m);
for(i=0;i<n;i++) {
for(j=0;j<m;j++) {
printf("a[%d][%d] = ", i, j); scanf("%d", &a[i][j]);
}
}
for(i=0;i<m;i++) {
printf("b[%d] = ", i); scanf("%d", &b[i]);
}
produs(a, b, m, c);
printf("\n");
put("Vectorul rezultat este: \n");
for(i=0;i<m;i++) {
printf("c[%d] = %d \n", i, c[i]);
}
}
Subscribe to:
Posts (Atom)