用 C++計算自然數的加權平均數的程式


給定一個自然數陣列和另一個包含相應自然數權重的陣列,任務是計算自然數的加權平均數。

有一個公式用於計算自然數的加權平均數。

$$\overline{x}=\frac{\displaystyle\sum\limits_{i=1}^n (x_{i*}w_{i})}{\displaystyle\sum\limits_{i=1}^n w_{i}}$$

其中,x 是自然數,w 是與自然數關聯的權重。

輸入 

X[] = {11, 22, 43, 34, 25, 16}
W[] = {12, 12, 43, 54, 75, 16}

輸出 

weighted mean is : 29.3019

說明 

(11*12 + 22*12 + 43*43 + 34*54 + 25*75 + 16*16) / (12 + 12 + 43 + 54 +75 +16)

輸入 

X[] = {3, 4, 5, 6, 7}
W[] = {4, 5, 6, 7, 8}

輸出 

weighted mean is : 5.33333

說明 

(3*4 + 4*5 + 5*6 + 6*7 + 7*8) / (4 + 5 + 6 + 7 + 8)

下面程式中使用的方法如下

  • 輸入兩個不同的陣列,一個用於自然數,另一個用於相應自然數的權重。

  • 應用公式計算自然數的加權平均數

  • 列印相應的結果。

演算法

Start
Step1→ declare function to calculate weighted means of natural numbers
   float weightedmean(int X[], int W[], int size)
      Declare int sum = 0, weight = 0
      Loop For int i = 0 and i < size and i++
         Set weight = weight + X[i] * W[i]
         Set sum = sum + W[i]
      End
      return (float)weight / sum
Step 2→ In main()
   Declare int X[] = {11, 22, 43, 34, 25, 16}
   Declare int W[] = {12, 12, 43, 54, 75, 16}
   Declare int size_X = sizeof(X)/sizeof(X[0])
   Declare int size_W = sizeof(W)/sizeof(W[0])
   IF (size_X == size_W)
      Call weightedmean(X, W, size_X)
   End
   Else
      Print -1
   End
Stop

示例

 線上演示

#include<bits/stdc++.h>
using namespace std;
//calculate weighted mean.
float weightedmean(int X[], int W[], int size){
   int sum = 0, weight = 0;
   for (int i = 0; i < size; i++){
      weight = weight + X[i] * W[i];
      sum = sum + W[i];
   }
   return (float)weight / sum;
}
int main(){
   int X[] = {11, 22, 43, 34, 25, 16};
   int W[] = {12, 12, 43, 54, 75, 16};
   int size_X = sizeof(X)/sizeof(X[0]);
   int size_W = sizeof(W)/sizeof(W[0]);
   if (size_X == size_W)
      cout<<"weighted mean is : "<<weightedmean(X, W, size_X);
   else
      cout << "-1";
   return 0;
}

輸出

如果執行上面的程式碼,它將生成以下輸出 −

weighted mean is : 29.3019

更新日期: 2020 年 8 月 13 日

845 次瀏覽

開啟你的 職業生涯

完成課程認證

開始吧
廣告