久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 1378|回復(fù): 4
收起左側(cè)

分享一個(gè)C語(yǔ)言篩選并聯(lián)電阻阻值的計(jì)算程序

[復(fù)制鏈接]
ID:74687 發(fā)表于 2023-11-29 17:01 | 顯示全部樓層 |閱讀模式
我在網(wǎng)上找水泥電阻,想找到匹配功率和阻值的電阻比較難。用網(wǎng)上的并聯(lián)電阻計(jì)算器,手工算也很繁瑣,然后自己寫(xiě)了一個(gè)C程序,在已知可挑選的阻值的情況下,通過(guò)并聯(lián)3-4個(gè)電阻,這樣就可以得到自己需要的水泥電阻。
軟件輸入自己需要的阻值,回車(chē)后輸出并聯(lián)電阻的個(gè)數(shù),然后程序自動(dòng)篩選出誤差最小的方案。

單片機(jī)源程序如下:
  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存放的是我能買(mǎi)到電阻的阻值
  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先是用來(lái)存放誤差的,后來(lái)沒(méi)用
  13.         int num, flag;  //num為并聯(lián)電阻個(gè)數(shù),flag是是一個(gè)循環(huán)控制變量,用來(lái)控制輸入的值是否在數(shù)組arr1內(nèi),如果在就不進(jìn)行計(jì)算,直接輸出結(jié)果,如果數(shù)組里沒(méi)有,再進(jìn)行計(jì)算。
  14.         //printf("%f\n", arr1[0]);
  15.         flag = 0;
  16.         while (true) {
  17.                 printf("請(qǐng)輸入需要計(jì)算的阻值(范圍0.1-100):");
  18.                 scanf("%f", &res);

  19.                 printf("請(qǐng)輸入并聯(lián)電阻個(gè)數(shù)(3或者4):");
  20.                 scanf("%d", &num);
  21.                 //for循環(huán)為了查找我們輸入的阻值是否在數(shù)組arr1內(nèi),如果在直接在,跳出for循環(huán),判斷是否在數(shù)組arr1,是拿res和arr1內(nèi)各個(gè)數(shù)比較,如果誤差小于0.0001,那就判斷在數(shù)組內(nèi)。
復(fù)制代碼


評(píng)分

參與人數(shù) 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

ID:1042173 發(fā)表于 2023-11-30 14:57 | 顯示全部樓層
還是有點(diǎn)看不明,,,
回復(fù)

使用道具 舉報(bào)

ID:1042173 發(fā)表于 2023-11-30 14:58 | 顯示全部樓層
那行是并聯(lián)電阻計(jì)算算法(公式)的?
回復(fù)

使用道具 舉報(bào)

ID:74687 發(fā)表于 2023-12-1 12:13 | 顯示全部樓層
QQQQ987 發(fā)表于 2023-11-30 14:58
那行是并聯(lián)電阻計(jì)算算法(公式)的?

46行和52行
回復(fù)

使用道具 舉報(bào)

ID:74687 發(fā)表于 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("請(qǐng)輸入需要計(jì)算的阻值(范圍0.1-100):");
  17.         scanf("%f", &res);

  18.         printf("請(qǐng)輸入并聯(lián)電阻個(gè)數(shù)(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. }
復(fù)制代碼
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产精品免费在线 | 正在播放亚洲 | m豆传媒在线链接观看 | 国产中的精品av涩差av | 成人国产精品久久 | 韩国av网站在线观看 | 亚洲欧美日韩精品久久亚洲区 | 国产区在线观看 | 久久久久国产精品 | 蜜桃毛片 | 久久精品国产免费 | 午夜精品久久久久久久 | 日本免费一区二区三区视频 | 日韩av第一页 | 国产一级淫片免费视频 | 亚洲视频在线一区 | 草久久 | 中文字幕蜜臀 | 国产区精品 | 久久久久久国产精品 | 国产成人精品午夜 | 国产高清在线精品一区二区三区 | 91精品国产91久久综合桃花 | 狠狠爱视频 | 国产毛片久久久久久久久春天 | 久久综合av | 国产免费一区 | 激情小视频 | 日本视频免费观看 | 欧美一二精品 | 欧美日韩国产在线 | 欧美精品久久久久久久久老牛影院 | 青青草这里只有精品 | 亚洲一区日韩 | 亚洲大片在线观看 | 亚洲精品v | 久久精品成人 | 毛片国产 | 色站综合| 成人在线视频观看 | 国产福利在线播放 |