#include <stdio.h> // Извикване на библиотеката за 'printf' и 'scanf' за да могат да се използват тези функции
#include <math.h> // Извикване на библиотеката за математическите изчисления
#define PI 3.141592653 // Дефинираме числото PI
int m, i, x, y, z; // Задаваме променливи
float t, rsum;
float a[ 20 ] , b[ 20 ] , c[ 20 ] ; // Масиви за страни на триъгълника като 'а' и 'b' се задават ръчно
float A[ 20 ] , B[ 20 ] , C[ 20 ] ; // Масиви за ъгли на триъгълника като 'А' се задава ръчно
float r[ 20 ] , p[ 20 ] , S[ 20 ] , r2[ 20 ] ; // Масиви за радиус на вписаната в триъгълника окръжност 'r',полуметър 'p' и лице 'S'
int main( )
{
printf ( "\n ****************LEGENDA****************\n " ) ; printf ( " * No: - Nomer na triygylnika *\n " ) ; printf ( " * a - Strana 'a' na triygylnika *\n " ) ; printf ( " * b - Strana 'b' na triygylnika *\n " ) ; printf ( " * c - Strana 'c' na triygylnika *\n " ) ; printf ( " * A - Ygyl 'A' na triygylnika *\n " ) ; printf ( " * B - Ygyl 'B' na triygylnika *\n " ) ; printf ( " * C - Ygyl 'C' na triygylnika *\n " ) ; printf ( " * r - Radius na wpisanata okryjnost *\n " ) ; printf ( " ***************************************\n \n " ) ;
Nachalo: // Място от където да продължи ако условието за 'М' не е спазено
printf ( " Molq vyvedete broj triygylnici M:" ) ; // Изписване на екрана scanf ( "%d" ,& m
) ; // Усвояване на стойност за броя на триъгълниците if ( m> 19 ) // Проверка за М<20
{
printf ( " Broq triygylnici trqbwa da e po malyk ot 20!\n \n " ) ; // Изписване на екрана goto Nachalo; // Ако условието(М<20) не е спазено програмата се връща в началото
}
getchar ( ) ; // Изчакване за натискане на клавиш от клавиатурата for ( i= 1 ; i<= m;++ i) // Цикъл за да може да се усвоят стойности за всички 'М' на брой триъгълника
{
printf ( " Molq vyvedete na '%d' triygylnik strana 'a':" , i
) ; // Изписване на екрана scanf ( "%f" ,& a
[ i
] ) ; // Усвояване на стойност за страната 'а' printf ( " Molq vyvedete na '%d' triygylnik strana 'b':" , i
) ; // Изписване на екрана scanf ( "%f" ,& b
[ i
] ) ; // Усвояване на стойност за страната 'b' printf ( " Molq vyvedete na '%d' triygylnik ygyla 'A':" , i
) ; // Изписване на екрана scanf ( "%f" ,& A
[ i
] ) ; // Усвояване на стойност за ъгъла 'А' }
printf ( "\n \n Izchislqvane i vizualizirane na cqlata informaciq za triygylnicite:\n " ) ; getchar ( ) ; // Изчакване за натискане на клавиш от клавиатурата for ( i= 1 ; i<= m;++ i) // Цикъл за изчисляване на стойностите
{
c
[ i
] = sqrt ( a
[ i
] * a
[ i
] + b
[ i
] * b
[ i
] - 2 * a
[ i
] * b
[ i
] * cos ( A
[ i
] * ( PI
/ 180.0 ) ) ) ; // Изчисляваме дължината на страна 'c' по косинусова теорема c.c = a.a + b.b – 2a.b.cos(A) p[ i] = ( a[ i] + b[ i] + c[ i] ) / 2 ; // Изчисляваме полупериметъра на триъгълника p=(a+b+c)/2
S
[ i
] = sqrt ( p
[ i
] * ( p
[ i
] - a
[ i
] ) * ( p
[ i
] - b
[ i
] ) * ( p
[ i
] - c
[ i
] ) ) ; // Изчисляваме лице на този триъгълник е по формула на Херон S=sqrt(p*(p-a)*(p-b)*p-c)) r[ i] = S[ i] / p[ i] ; // Изчисляваме радиус на вписана окръжност r = S/p
B
[ i
] = ( acos ( ( a
[ i
] * a
[ i
] + c
[ i
] * c
[ i
] - b
[ i
] * b
[ i
] ) / ( 2 * a
[ i
] * c
[ i
] ) ) * 180.0 ) / PI
; // Косинусова теорема за откриване радиуса на ъглите b.b = a.a + c.c – 2a.c.cos(B) C[ i] = 180 - A[ i] - B[ i] ; // Изчислява се като общия сбор на вътрешните ъгли на триъгълник трябва да е равно на 180
printf ( "\n No:%d a=%.2f b=%.2f c=%.2f A=%.2f B=%.2f C=%.2f r=%.2f\n " , i
, a
[ i
] , b
[ i
] , c
[ i
] , A
[ i
] , B
[ i
] , C
[ i
] , r
[ i
] ) ; }
//*****************************************
printf ( "\n \n Podredba na triygylnicite po vazhodqsht red sprqmo radiusa na wpisanata okryjnost (r)\n " ) ;
for ( i = 1 ; i <= m; i++ ) // Copying data from array 'r' to array 'r2
{
r2[ i] = r[ i] ;
}
for ( x= 1 ; x<= m; ++ x) // Сортиране чрез метода на мехурчето
for ( y= m; y>= x; -- y)
{
if ( r2[ y- 1 ] > r2[ y] ) // Сравняване на съседни елементи
{
t = r2[ y- 1 ] ;
r2[ y- 1 ] = r2[ y] ;
r2[ y] = t;
}
}
for ( z= 1 ; z<= m; z++ ) {
for ( i= 1 ; i<= m; i++ ) {
if ( r2[ z] == r[ i] ) {
printf ( "\n No:%d a=%.2f b=%.2f c=%.2f A=%.2f B=%.2f C=%.2f r=%.2f\n " , i
, a
[ i
] , b
[ i
] , c
[ i
] , A
[ i
] , B
[ i
] , C
[ i
] , r
[ i
] ) ; // Изписване на триъгълниците ж жъзходящ ред }
}
}
rsum = 0 ;
for ( i = 1 ; i <= m ; i++ )
rsum = rsum + r[ i] ; // Събиране на радиусите
printf ( "\n \n Obshtiq sbor na radiusa na wpisanata okryjnost: %.2f \n " , rsum
) ; getchar ( ) ; // Изчакване за натискане на клавиш от клавиатурата
return 0 ;
}
#include <stdio.h>																		// Извикване на библиотеката за 'printf' и 'scanf' за да могат да се използват тези функции
#include <math.h>																		// Извикване на библиотеката за математическите изчисления

#define PI 3.141592653																	// Дефинираме числото PI

int m,i,x,y,z;																        		// Задаваме променливи
float t,rsum;
float a[20],b[20],c[20];																// Масиви за страни на триъгълника като 'а' и 'b' се задават ръчно
float A[20],B[20],C[20];																// Масиви за ъгли на триъгълника като 'А' се задава ръчно
float r[20],p[20],S[20],r2[20];																// Масиви за радиус на вписаната в триъгълника окръжност 'r',полуметър 'p' и лице 'S'

int main()
	{
				printf("\n ****************LEGENDA****************\n");
				printf(" * No: - Nomer na triygylnika          *\n");
				printf(" * a   - Strana 'a' na triygylnika     *\n");
				printf(" * b   - Strana 'b' na triygylnika     *\n");
				printf(" * c   - Strana 'c' na triygylnika     *\n");
				printf(" * A   - Ygyl   'A' na triygylnika     *\n");
				printf(" * B   - Ygyl   'B' na triygylnika     *\n");
				printf(" * C   - Ygyl   'C' na triygylnika     *\n");
				printf(" * r   - Radius na wpisanata okryjnost *\n");
				printf(" ***************************************\n\n");

		Nachalo:																		// Място от където да продължи ако условието за 'М' не е спазено
				printf(" Molq vyvedete broj triygylnici M:");									// Изписване на екрана
		scanf("%d",&m);																	// Усвояване на стойност за броя на триъгълниците
		if (m>19)																		// Проверка за М<20
			{
				printf(" Broq triygylnici trqbwa da e po malyk ot 20!\n\n");				// Изписване на екрана
				goto Nachalo;															// Ако условието(М<20) не е спазено програмата се връща в началото
			}
		getchar();																		// Изчакване за натискане на клавиш от клавиатурата
		for(i=1;i<=m;++i)																// Цикъл за да може да се усвоят стойности за всички 'М' на брой триъгълника
			{
				printf(" Molq vyvedete na '%d' triygylnik strana 'a':",i);				// Изписване на екрана
				scanf("%f",&a[i]);														// Усвояване на стойност за страната 'а' 
				printf(" Molq vyvedete na '%d' triygylnik strana 'b':",i);				// Изписване на екрана
				scanf("%f",&b[i]);														// Усвояване на стойност за страната 'b' 
				printf(" Molq vyvedete na '%d' triygylnik ygyla 'A':",i);				// Изписване на екрана
				scanf("%f",&A[i]);														// Усвояване на стойност за ъгъла 'А'
			}

			printf("\n\n Izchislqvane i vizualizirane na cqlata informaciq za triygylnicite:\n");
			getchar();																    // Изчакване за натискане на клавиш от клавиатурата
		for (i=1;i<=m;++i)																// Цикъл за изчисляване на стойностите                                                    
			{
				c[i]=sqrt(a[i]*a[i]+b[i]*b[i]-2*a[i]*b[i]*cos(A[i]*(PI/180.0)));		// Изчисляваме дължината на страна 'c' по косинусова теорема c.c = a.a + b.b – 2a.b.cos(A)
				p[i]=(a[i]+b[i]+c[i])/2 ;												// Изчисляваме полупериметъра на триъгълника p=(a+b+c)/2
				S[i]=sqrt(p[i]*(p[i]-a[i])*(p[i]-b[i])*(p[i]-c[i]));					// Изчисляваме лице на този триъгълник е по формула на Херон S=sqrt(p*(p-a)*(p-b)*p-c))
				r[i]=S[i]/p[i];															// Изчисляваме радиус на вписана окръжност r = S/p
				B[i]=(acos((a[i]*a[i]+c[i]*c[i]-b[i]*b[i])/(2*a[i]*c[i]))*180.0)/PI;    // Косинусова теорема за откриване радиуса на ъглите b.b = a.a + c.c – 2a.c.cos(B)
				C[i]=180-A[i]-B[i];                                                     // Изчислява се като общия сбор на вътрешните ъгли на триъгълник трябва да е равно на 180

				printf("\n No:%d       a=%.2f       b=%.2f       c=%.2f       A=%.2f       B=%.2f       C=%.2f       r=%.2f\n",i,a[i],b[i],c[i],A[i],B[i],C[i],r[i]);
			}

		//*****************************************
		printf("\n\n Podredba na triygylnicite po vazhodqsht red sprqmo radiusa na wpisanata okryjnost (r)\n");

			   for (i = 1; i <= m; i++)                                                  // Copying data from array 'r' to array 'r2 
			   {
				  r2[i] = r[i];
			   }

       for(x=1; x<=m; ++x)                                                               // Сортиране чрез метода на мехурчето
			for(y=m; y>=x; --y)
				{     
						if(r2[y-1] > r2[y])                                              //	Сравняване на съседни елементи 
						{
								t = r2[y-1];
								r2[y-1] = r2[y];
								r2[y] = t;
					    }
				}

			for( z=1; z<=m; z++){
					for( i=1; i<=m; i++){
						if (r2[z]==r[i]){
							printf("\n No:%d       a=%.2f       b=%.2f       c=%.2f       A=%.2f       B=%.2f       C=%.2f       r=%.2f\n",i,a[i],b[i],c[i],A[i],B[i],C[i],r[i]);  // Изписване на триъгълниците ж жъзходящ ред 
						}
					}
			}
		   rsum = 0;
		   for (i = 1; i <=m ; i++)
			  rsum = rsum + r[i];                                                        // Събиране на радиусите
		   		printf("\n\n Obshtiq sbor na radiusa na wpisanata okryjnost:  %.2f \n",rsum);
			getchar();																     // Изчакване за натискане на клавиш от клавиатурата

		return 0;
	}