找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 533|回复: 4
收起左侧

分享一个C语言筛选并联电阻阻值的计算程序

[复制链接]
ID:74687 发表于 2023-11-29 17:01 | 显示全部楼层 |阅读模式
我在网上找水泥电阻,想找到匹配功率和阻值的电阻比较难。用网上的并联电阻计算器,手工算也很繁琐,然后自己写了一个C程序,在已知可挑选的阻值的情况下,通过并联3-4个电阻,这样就可以得到自己需要的水泥电阻。
软件输入自己需要的阻值,回车后输出并联电阻的个数,然后程序自动筛选出误差最小的方案。

单片机源程序如下:
  1. #include <stdio.h>
  2. #include <math.h>
  3. #include <stdbool.h>

  4. float Res_cal(float a, float b, float c, float d);
  5. float Res_cal2(float a, float b, float c);
  6. int float_equal(float x, float y, float epsilon);
  7. void screen1(float res);
  8. void screen2(float res);
  9. //arr1存放的是我能买到电阻的阻值
  10. float arr1[32] = {0.1, 0.5, 1, 1.5, 2, 2.5, 3, 3.3, 4, 5, 6, 8, 10, 12, 15, 20, 22, 25, 30, 33, 39, 47, 50, 68, 75, 100, 120, 150, 200, 300, 330, 500};

  11. void main() {

  12.         float res, mistake; //变量res为输入的阻值,mistake先是用来存放误差的,后来没用
  13.         int num, flag;  //num为并联电阻个数,flag是是一个循环控制变量,用来控制输入的值是否在数组arr1内,如果在就不进行计算,直接输出结果,如果数组里没有,再进行计算。
  14.         //printf("%f\n", arr1[0]);
  15.         flag = 0;
  16.         while (true) {
  17.                 printf("请输入需要计算的阻值(范围0.1-100):");
  18.                 scanf("%f", &res);

  19.                 printf("请输入并联电阻个数(3或者4):");
  20.                 scanf("%d", &num);
  21.                 //for循环为了查找我们输入的阻值是否在数组arr1内,如果在直接在,跳出for循环,判断是否在数组arr1,是拿res和arr1内各个数比较,如果误差小于0.0001,那就判断在数组内。
复制代码


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:1042173 发表于 2023-11-30 14:57 | 显示全部楼层
还是有点看不明,,,
回复

使用道具 举报

ID:1042173 发表于 2023-11-30 14:58 | 显示全部楼层
那行是并联电阻计算算法(公式)的?
回复

使用道具 举报

ID:74687 发表于 2023-12-1 12:13 | 显示全部楼层
QQQQ987 发表于 2023-11-30 14:58
那行是并联电阻计算算法(公式)的?

46行和52行
回复

使用道具 举报

ID:74687 发表于 2023-12-1 13:21 | 显示全部楼层
接前面的代码
  1. #include <stdio.h>
  2. #include <math.h>
  3. #include <stdbool.h>

  4. float Res_cal(float a, float b, float c, float d);
  5. float Res_cal2(float a, float b, float c);
  6. int float_equal(float x, float y, float epsilon);
  7. void screen1(float res);
  8. void screen2(float res);

  9. float arr1[32] = {0.1, 0.5, 1, 1.5, 2, 2.5, 3, 3.3, 4, 5, 6, 8, 10, 12, 15, 20, 22, 25, 30, 33, 39, 47, 50, 68, 75, 100, 120, 150, 200, 300, 330, 500};

  10. void main() {

  11.     float res, mistake;
  12.     int num, flag;
  13.     //printf("%f\n", arr1[0]);
  14.     flag = 0;
  15.     while (true) {
  16.         printf("请输入需要计算的阻值(范围0.1-100):");
  17.         scanf("%f", &res);

  18.         printf("请输入并联电阻个数(3或者4):");
  19.         scanf("%d", &num);

  20.         for (int i = 0; i < 32; i++) {
  21.             if (float_equal(res, arr1[i], 0.0001)) {
  22.                 printf("arr1[%d]:%g\r\n", i, arr1[i]);
  23.                 flag = 1;
  24.                 break;
  25.             }
  26.         }
  27.         if ( !flag) {
  28.             if (3 == num)
  29.                 screen1(res);
  30.             else
  31.                 screen2(res);
  32.         }
  33.         flag = 0;
  34.         printf("***********************************************************\r\n");
  35.     }
  36. }

  37. float Res_cal(float a, float b, float c, float d) {
  38.     float result;
  39.     result = 1 / (1 / a + 1 / b + 1 / c + 1 / d);
  40.     return result;
  41. }

  42. float Res_cal2(float a, float b, float c) {
  43.     float result;
  44.     result = 1 / (1 / a + 1 / b + 1 / c );
  45.     return result;
  46. }

  47. int float_equal(float x, float y, float epsilon) {
  48.     if (fabs(x - y) < epsilon)
  49.         return 1;
  50.     else
  51.         return 0;
  52. }

  53. void screen2(float res) {
  54.     int arr[4];
  55.     float result, flag = 1;
  56.     for (int i = 0; i < 32; i++) {
  57.         for (int j = i; j < 32; j++) {
  58.             for (int k = i; k < 32; k++) {
  59.                 for (int l = i; l < 32; l++) {
  60.                     if (flag > fabs(Res_cal(arr1[i], arr1[j], arr1[k], arr1[l]) - res)) {
  61.                         flag = fabs(Res_cal(arr1[i], arr1[j], arr1[k], arr1[l]) - res);
  62.                         result = Res_cal(arr1[i], arr1[j], arr1[k], arr1[l]);
  63.                         arr[0] = i;
  64.                         arr[1] = j;
  65.                         arr[2] = k;
  66.                         arr[3] = l;
  67.                     }
  68.                 }
  69.             }
  70.         }
  71.     }
  72.     printf("arr1[%d]:%g  arr1[%d]:%g arr1[%d]:%g arr1[%d]:%g 阻值:%g\r\n", arr[0], arr1[arr[0]], arr[1], arr1[arr[1]],
  73.            arr[2],
  74.            arr1[arr[2]], arr[3], arr1[arr[3]], result);
  75. }

  76. void screen1(float res) {
  77.     int arr[3];
  78.     float result, flag = 1;
  79.     for (int i = 0; i < 32; i++) {
  80.         for (int j = i; j < 32; j++) {
  81.             for (int k = i; k < 32; k++) {
  82.                 if (flag > fabs(Res_cal2(arr1[i], arr1[j], arr1[k]) - res)) {
  83.                     flag = fabs(Res_cal2(arr1[i], arr1[j], arr1[k]) - res);
  84.                     result = Res_cal2(arr1[i], arr1[j], arr1[k]);
  85.                     arr[0] = i;
  86.                     arr[1] = j;
  87.                     arr[2] = k;
  88.                 }
  89.             }
  90.         }
  91.     }
  92.     printf("arr1[%d]:%g  arr1[%d]:%g arr1[%d]:%g 阻值:%g\r\n", arr[0], arr1[arr[0]], arr[1], arr1[arr[1]], arr[2],
  93.            arr1[arr[2]], result);
  94. }
复制代码
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表