freesky

task_sem1_1.1

Nov 3rd, 2012
92
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 0.83 KB | None | 0 0
  1. #include <stdio.h>
  2. #include <math.h>
  3.  
  4. #define W 1.008e-14
  5.  
  6. double ph(double va, double na, double vb, double nb) {
  7.     double a, b, v, c, p;
  8.  
  9.     a = va * na;
  10.     b = vb * nb;
  11.     v = va + vb;
  12.  
  13.     p = (a - b) / v;
  14.     c = fabs(p / 2) + sqrt(pow(p, 2) / 4 + W);
  15.  
  16.     if (p >= 0)
  17.         return -log10(c);
  18.     else
  19.         return -log10(W) + log10(c);  
  20. }
  21.  
  22. int main(int argc, char *argv[]) {
  23.     double va, vb, na, nb;
  24.  
  25.     printf("Объем HCl, мл = "); scanf("%lf", &va);
  26.     printf("Концентрация HCl, моль/л = "); scanf("%lf", &na);
  27.  
  28.     putchar('\n');
  29.  
  30.     printf("Объем NaOH, мл = "); scanf("%lf", &vb);
  31.     printf("Концентрация NaOH, моль/л = "); scanf("%lf", &nb);
  32.  
  33.     putchar('\n'); putchar('\n');
  34.  
  35.     printf("pH = %g\n", ph(va, na, vb, nb));
  36.  
  37.     return 0;
  38. }
Advertisement
Add Comment
Please, Sign In to add comment