Advertisement
Guest User

Untitled

a guest
Dec 11th, 2013
229
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 9.19 KB | None | 0 0
  1. using System;
  2.  
  3. using System.Collections.Generic;
  4.  
  5. using System.Linq;
  6.  
  7. using System.Text;
  8.  
  9.  
  10.  
  11. namespace pgrabo68247
  12.  
  13. {
  14.  
  15.     class Program
  16.  
  17.     {
  18.  
  19.         static int pg_silnia(int pg_n_1)
  20.  
  21.         {
  22.  
  23.             //rekurencyjne wpisanie silni
  24.  
  25.             if (pg_n_1 == 0) return 1;
  26.  
  27.             else return pg_n_1 * pg_silnia(pg_n_1 - 1);
  28.  
  29.            
  30.  
  31.         }
  32.  
  33.         static void Main(string[] args)
  34.  
  35.         {
  36.  
  37.             //Przypisanie typu danych
  38.  
  39.             String pg_odp;
  40.  
  41.             float pg_X, pg_EPS, pg_Y, pg_b;
  42.  
  43.             int pg_n, pg_w, pg_index_1, pg_index_2;
  44.  
  45.             float pg_Xd, pg_h, pg_Xg;
  46.  
  47.             float[,] pg_tab;
  48.  
  49.  
  50.  
  51.             do
  52.  
  53.             {
  54.  
  55.                 //Wypisanie metryki programu
  56.  
  57.                 Console.WriteLine("\n\t\tProgram dla zadania pierwszego. Wybierz jedną z opcji:" +
  58.  
  59.                                   "\n\t1.Określenie wartości funkcji w podanym punkcie wartości zmiennej" +
  60.  
  61.                                   "\n\tniezależnej X i przy określonej dokładności EPS " +
  62.  
  63.                                   "\n\t2.Tablicowanie funkcji w podanym przedziale [Xd,Xg] z krokiem h i" +
  64.  
  65.                                   "\n\tprzy określonej dokładności EPS.");
  66.  
  67.             start:
  68.  
  69.                 Console.Write("\n\tWybierz 1 lub 2: ");
  70.  
  71.                 pg_w = Convert.ToInt16(Console.ReadLine());
  72.  
  73.                 switch (pg_w)
  74.  
  75.                 {
  76.  
  77.                     case 1:
  78.  
  79.                         //Wczytywanie danych
  80.  
  81.                         Console.Write("\n\tPodaj wartość zmiennej niezależnej X: ");
  82.  
  83.                         pg_X = Convert.ToSingle(Console.ReadLine());
  84.  
  85.  
  86.  
  87.                         //Wczytanie dokładności obliczeń
  88.  
  89.                         do
  90.  
  91.                         {
  92.  
  93.                             Console.Write("\n\tPodaj dokładność obliczeń EPS: ");
  94.  
  95.                             pg_EPS = Convert.ToSingle(Console.ReadLine());
  96.  
  97.                             if ((pg_EPS <= 0) || (pg_EPS >= 1))
  98.  
  99.                             {
  100.  
  101.                                 Console.Write("\n\tERROR: Dokładność obliczeń musi spełniać warunek: " +
  102.  
  103.                                               "\n\t0 < EPS < 1");
  104.  
  105.                                 Console.Write("\n\tWprowadz dokładnośc obliczeń jeszcze raz.");
  106.  
  107.                             }
  108.  
  109.                         } while ((pg_EPS <= 0) || (pg_EPS >= 1));
  110.  
  111.  
  112.  
  113.                         //Sprawdzenie warunków funkcji
  114.  
  115.                         if (pg_X < -1)
  116.  
  117.                         {
  118.  
  119.                             pg_n = 0;
  120.  
  121.                            //do
  122.  
  123.                             // {
  124.  
  125.                             pg_Y = (float)Math.Pow(-1, pg_n) * (float)Math.Pow(pg_X, 2 * pg_n + 1) / pg_silnia(2 * pg_n + 1);
  126.  
  127.                             Console.Write("\n\tWartość dla podanego X wynosi: {0}", pg_Y);
  128.  
  129.                             //     pg_n++;
  130.  
  131.                             // } while (pg_n <= 15);
  132.  
  133.                         }
  134.  
  135.                         if ((pg_X <= 1) && (pg_X >= -1))
  136.  
  137.                         {
  138.  
  139.                             pg_n = 1;
  140.  
  141.                             //do
  142.  
  143.                             //{
  144.  
  145.                             pg_Y = (float)Math.Pow(-1, pg_n) * (float)Math.Pow(pg_X, pg_n) / pg_silnia(2 * pg_n);
  146.  
  147.                             Console.Write("\n\tWartość dla podanego X wynosi: {0}", pg_Y);
  148.  
  149.                             //    pg_n++;
  150.  
  151.                             // } while (pg_n <= 15);
  152.  
  153.                         }
  154.  
  155.                         if (pg_X > 1)
  156.  
  157.                         {
  158.  
  159.                             pg_n = 1;
  160.  
  161.                             do
  162.  
  163.                             {
  164.  
  165.                                 //wczytanie zmiennej b
  166.  
  167.                                 Console.Write("\n\tPodaj wartość zmiennej b(b>0): ");
  168.  
  169.                                 pg_b = Convert.ToSingle(Console.ReadLine());
  170.  
  171.                                 if (pg_b <= 0)
  172.  
  173.                                     Console.Write("\n\tERROR: b musi być większe od zera.");
  174.  
  175.                             } while (pg_b <= 0);
  176.  
  177.                             // do
  178.  
  179.                             // {
  180.  
  181.                             pg_Y = (float)Math.Pow(Math.Log(pg_b), pg_n) * (float)Math.Pow(pg_X, pg_n) / pg_silnia(pg_n);
  182.  
  183.                             Console.Write("\n\tWartość dla podanego X wynosi: {0}", pg_Y);
  184.  
  185.                             //   pg_n++;
  186.  
  187.                             //} while (pg_n <= 15);
  188.  
  189.                         }
  190.  
  191.  
  192.  
  193.                         break;
  194.  
  195.                     case 2:
  196.  
  197.                         //Wczytanie zmiennych
  198.  
  199.                         Console.Write("\n\tPodaj dolną wartość zmiennej niezależnej X: ");
  200.  
  201.                         pg_Xd = Convert.ToSingle(Console.ReadLine());
  202.  
  203.                         do
  204.  
  205.                         {
  206.  
  207.                             Console.Write("\n\tPodaj górną wartość zmiennej niezależnej X: ");
  208.  
  209.                             pg_Xg = Convert.ToSingle(Console.ReadLine());
  210.  
  211.                             if (pg_Xg <= pg_Xd)
  212.  
  213.                                 Console.Write("\n\tGórna wartość X musi być większa od dolnej !! ");
  214.  
  215.  
  216.  
  217.                         } while (pg_Xg <= pg_Xd);
  218.  
  219.  
  220.  
  221.                         Console.Write("\n\tPodaj h: ");
  222.  
  223.                         pg_h = Convert.ToSingle(Console.ReadLine());
  224.  
  225.  
  226.  
  227.                         do
  228.  
  229.                         {
  230.  
  231.                             //wczytanie zmiennej b
  232.  
  233.                             Console.Write("\n\tPodaj wartość zmiennej b(b>0) dla x>0: ");
  234.  
  235.                             pg_b = Convert.ToSingle(Console.ReadLine());
  236.  
  237.                             if (pg_b <= 0)
  238.  
  239.                                 Console.Write("\n\tERROR: b musi być większe od zera.");
  240.  
  241.                         } while (pg_b <= 0);
  242.  
  243.  
  244.  
  245.                         //Wczytanie dokładności obliczeń
  246.  
  247.                         do
  248.  
  249.                         {
  250.  
  251.                             Console.Write("\n\tPodaj dokładność obliczeń EPS: ");
  252.  
  253.                             pg_EPS = Convert.ToSingle(Console.ReadLine());
  254.  
  255.                             if ((pg_EPS <= 0) || (pg_EPS >= 1))
  256.  
  257.                             {
  258.  
  259.                                 Console.Write("\n\tERROR: Dokładność obliczeń musi spełniać warunek: " +
  260.  
  261.                                               "\n\t0 < EPS < 1");
  262.  
  263.                                 Console.Write("\n\tWprowadz dokładnośc obliczeń jeszcze raz.");
  264.  
  265.                             }
  266.  
  267.                         } while ((pg_EPS <= 0) || (pg_EPS >= 1));
  268.  
  269.  
  270.  
  271.                         //Obliczenia i dodawanie do tablicy
  272.  
  273.                         pg_index_1 = 0;
  274.  
  275.                         pg_index_2 = 0;
  276.  
  277.                         pg_tab = new float[pg_index_1, pg_index_2];
  278.  
  279.  
  280.  
  281.                         do
  282.  
  283.                         {
  284.  
  285.                             if (pg_Xd < -1)
  286.  
  287.                             {
  288.  
  289.                                 pg_n = 0;
  290.  
  291.                                 pg_Y = (float)Math.Pow(-1, pg_n) * (float)Math.Pow(pg_Xd, 2 * pg_n + 1) / pg_silnia(2 * pg_n + 1);
  292.  
  293.                                 pg_tab[pg_index_1, pg_index_2] = pg_Xd;
  294.  
  295.                                 pg_tab[pg_index_1, pg_index_2 + 1] = pg_Y;
  296.  
  297.                                 pg_index_1++;
  298.  
  299.                                 pg_index_2++;
  300.  
  301.                                 pg_Xd = pg_Xd + pg_h;
  302.  
  303.                             }
  304.  
  305.                             if ((pg_Xd <= 1) && (pg_Xd >= -1))
  306.  
  307.                             {
  308.  
  309.                                 pg_n = 1;
  310.  
  311.                                 pg_Y = (float)Math.Pow(-1, pg_n) * (float)Math.Pow(pg_Xd, pg_n) / pg_silnia(2 * pg_n);
  312.  
  313.                                 pg_tab[pg_index_1, pg_index_2] = pg_Xd;
  314.  
  315.                                 pg_tab[pg_index_1, pg_index_2 + 1] = pg_Y;
  316.  
  317.                                 pg_index_1++;
  318.  
  319.                                 pg_index_2++;
  320.  
  321.                                 pg_Xd = pg_Xd + pg_h;
  322.  
  323.                             }
  324.  
  325.                             if (pg_Xd > 1)
  326.  
  327.                             {
  328.  
  329.                                 pg_n = 1;
  330.  
  331.                                 pg_Y = (float)Math.Pow(Math.Log(pg_b), pg_n) * (float)Math.Pow(pg_Xd, pg_n) / pg_silnia(pg_n);
  332.  
  333.                                 pg_tab[pg_index_1, pg_index_2] = pg_Xd;
  334.  
  335.                                 pg_tab[pg_index_1, pg_index_2 + 1] = pg_Y;
  336.  
  337.                                 pg_index_1++;
  338.  
  339.                                 pg_index_2++;
  340.  
  341.                                 pg_Xd = pg_Xd + pg_h;
  342.  
  343.  
  344.  
  345.                             }
  346.  
  347.                         } while (pg_Xd <= pg_Xg);
  348.  
  349.                         break;
  350.  
  351.  
  352.  
  353.                     default:
  354.  
  355.                         Console.Write("\n\tERROR: wciśnij 1 lub 2!\n");
  356.  
  357.                         goto start;
  358.  
  359.                 }
  360.  
  361.                 Console.Write("\n\tCzy chcesz powtarzać szukanie liczby doskonałej? (T/N): ");
  362.  
  363.                 pg_odp = Console.ReadLine().ToUpper();
  364.  
  365.             } while (pg_odp == "T");
  366.  
  367.         }
  368.  
  369.     }
  370.  
  371. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement