C语言 求方差

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言 求方差相关的知识,希望对你有一定的参考价值。

方差用于描述一批数据的离散程度。编写程序,从键盘输入5个实数x1,x2,x3,x4,x5,计算出它们的方差,并输出(结果保留4位小数,使用double型数据)。提示:假设这5个数的平均值为m,则方差

v = 1/5[(m-x1)^2 + (m-x2)^2 + (m-x3)^2 + (m-x4)^2 + (m-x5)^2]^(1/2).
其中^表示平方,请你选择适当的运算符表示。

直接上代码:

#include <stdio.h>
#include <conio.h>
#include <math.h>
double fangcha(double x[], int n)
 //求数组x(具有n个元素)的方差:S=(<x^2>-<x>)^0.5
 int i;
 double xaver=0.0, x2aver=0.0;
 for(i=0;i<n;++i)
  xaver+=x[i]; x2aver+=x[i]*x[i];
 
 xaver/=n; x2aver/=n; //求x的平均、x^2的平均
 return sqrt(x2aver-xaver*xaver);

int main()
 double x[5];
 int i;
 printf("Input 5 datas:\\n");
 for(i=0;i<5;++i)
  scanf("%lf",&x[i]);
 
 printf("\\nFangCha S=%.4lf",fangcha(x,5));
 printf("\\nFinished!\\n");
 getch();
 return 0;

希望能帮助到你。

参考技术A #include <stdio.h>
#include <math.h>

const int MAXSIZE = 100;

double variance(double arr[],int n) 
int i;
double sum = 0,tmp = 0,x_;
for(i = 0; i < n; ++i) sum += arr[i];
x_ = sum / n;
for(i = 0; i < n; ++i)
tmp += (arr[i] - x_) * (arr[i] - x_);
return sqrt(tmp);



int main() 
int n = 0;
double arr[MAXSIZE];
printf("输入一个数('q' to quit):");
while(scanf("%lf",&arr[n]) == 1 && n < MAXSIZE) 
printf("输入一个数('q' to quit):");
++n;

fflush(stdin);
printf("样本数据:%d个\\n",n);
printf("方差是:%.4lf\\n",variance(arr,n));
return 0;

追问

谢谢!

参考技术B #include<stdio.h>
#include<math.h>

void mian()

double x1,x2,x3,x4,x5,m,d;
printf("Please input your number:\n");
scanf("%f%f%f%f%f",&x1,&x2,&x3,&x4,&x5);
m=(x1+x2+x3+x4+x5)/5;
d=sqrt((pow((m-x1),2)+pow((m-x2),2)+pow((m-x3),2)+pow((m-x4),2)+(pow((m-x5),2)))/5);
printf("V is:%f\n",d);
//system("pause");

汇编语言实现求两个数的最小公约数,平方差,各占和的百分比

按下列要求编程:

(1)输入两个小于100的十进制正整数。

(2)求出这两个数的所有公约数。

(3)求出这两个数的平方差,若是负的要输出负号。

(4)计算两个数各占和的百分比,并且按照“ %”的格式输出(小数点后保留两位)。

(5)数据的输入和结果的输出都要有必要的提示,且提示独占一行。

(6)要使用到子程序。

技术图片技术图片?

源代码: 

技术图片
  1 data segment
  2     hh db 0dh,0ah,$
  3     m1 db please enter a number:,0dh,0ah,$
  4     m2 db please enter another number:,0dh,0ah,$
  5     m3 db gong yue shu:,0dh,0ah,$
  6     m4 db ping fang cha:,0dh,0ah,$
  7     m5 db num1/sum is:,0dh,0ah,$
  8     m6 db num2/sum is:,0dh,0ah,$
  9     sum dw 0
 10     x dw 0
 11     y dw 0
 12     z dw 0
 13     sign db 0h
 14     s db 6 dup(0h),$
 15 data ends
 16 
 17 code segment
 18     assume cs:code,ds:data
 19     main proc far
 20     start:
 21         mov ax,data
 22         mov ds,ax
 23         mov ax,offset m1
 24         call print
 25         call enternumber
 26         mov bx,ax
 27         mov x,bx
 28         mov sum,bx
 29         
 30         mov ax,offset m2
 31         call print
 32         call enternumber
 33         mov cx,ax
 34         mov y,cx
 35         add sum,cx
 36         
 37         call find
 38         mov ax,offset m3
 39         call print
 40         mov ax,cx
 41          
 42         mov bl,al
 43         mov bh,1
 44         l1:
 45             mov al,bl
 46             xor ah,ah
 47             div bh
 48             cmp ah,0
 49             jnz next2
 50             mov al,bh
 51             aam
 52             mov cx,ax
 53             add ch,30h
 54             mov dl,ch
 55             mov ah,2
 56             int 21h
 57             add cl,30h
 58             mov dl,cl
 59             mov ah,2
 60             int 21h
 61             mov dx,offset hh
 62             mov ah,09h
 63             int 21h
 64             
 65         next2:
 66             inc bh
 67             cmp bl,bh
 68             jl done
 69             jmp l1
 70         done:
 71             mov ax,offset m4
 72             call print
 73             call pfc
 74         
 75         
 76         mov ax,offset hh
 77         call print
 78         mov ax,offset m5
 79         call print
 80         mov al,byte ptr x
 81         mov bh,100
 82         mul bh
 83         mov bl,byte ptr sum
 84         div bl
 85         mov bl,al
 86         
 87         call disp10
 88         
 89         mov dl,%
 90         mov ah,02h
 91         int 21h
 92         
 93         mov ax,offset hh
 94         call print
 95         mov ax,offset m6
 96         call print
 97         
 98         mov al,byte ptr y
 99         mov bh,100
100         mul bh
101         mov bl,byte ptr sum
102         div bl
103         mov bl,al
104         call disp10
105         mov dl,%
106         mov ah,02h
107         int 21h
108         
109         mov ah,4ch
110         int 21h
111         
112         main endp
113 
114     print proc near
115         
116         mov dx,ax
117         mov ah,09h
118         int 21h
119         ret
120 
121     print endp
122     
123     enternumber proc near
124         
125         mov ah,01h
126         int 21h
127         mov dh,al
128         sub dh,30h
129         
130         mov ah,01h
131         int 21h
132         cmp al,0dh
133         jz next1
134         sub al,30h
135         shl dh,1
136         mov dl,dh
137         shl dh,1
138         shl dh,1
139         add dh,dl
140         add dh,al
141         
142         next1:
143             mov cl,dh
144             mov dx,offset hh
145             mov ah,09h
146             int 21h
147             mov al,cl
148             xor ah,ah
149         ret
150     enternumber endp
151     
152    find proc near
153        
154        cmp bx,cx
155        jnl first
156        xchg bx,cx
157        first:
158            xor dx,dx
159            mov ax,bx
160            div cx
161            cmp dx,0
162            jz equal
163            mov bx,cx
164            mov cx,dx
165            jmp first
166            
167        equal:
168            ret
169    find endp
170    
171    pfc proc near;  计算平方差
172        work:
173            mov al,byte ptr x
174            mul al
175            mov z,ax
176            mov al,byte ptr y
177            mul al
178            cmp z,ax
179            jb n1
180            sub z,ax
181            jmp n2
182            
183        n1:
184            sub ax,z
185            mov z,ax
186            mov sign,-
187        n2:
188            mov cx,5h
189            mov di,4h
190            mov bx,0ah
191            mov ax,z
192          
193        w2:
194            mov dx,0
195            div bx
196            add dl,30h
197            mov s[di],dl
198            dec di
199            cmp ax,0h
200            jz w2exit
201            loop w2
202        w2exit:
203            mov al,sign
204            mov s[di],al
205            mov di,0
206            
207        w3:
208            inc di
209            cmp s[di],0h
210            jz w3
211            lea dx,s[di]
212            mov ah,09h
213            int 21h
214        ret
215    pfc endp
216    
217    disp10 proc near  ;计算占和百分比
218        mov ah,0
219        mov al,bl
220        mov bh,100
221        div bh
222        mov bl,ah
223        mov dl,al
224        cmp dl,0
225        jz jump1
226        add dl,30h
227        mov ah,02
228        int 21h
229        jump1:
230            mov al,bl
231            mov ah,0
232            mov bh,10
233            div bh
234            mov bl,ah
235            mov dl,al
236            cmp dl,0
237            jz jump2
238            add dl,30h
239            mov ah,02
240            int 21h
241        jump2:
242            mov dl,bl
243            add dl,30h
244            mov ah,02h
245            int 21h 
246        ret
247 
248    disp10 endp
249 code ends
250 end start

 

运行示例:

技术图片技术图片?                                        技术图片技术图片?

以上是关于C语言 求方差的主要内容,如果未能解决你的问题,请参考以下文章

c语言题目,输入n个数到一维数组a中,求均方差。

c语言 求一组数的平均值及其均方差 写出程序,谢谢!

c语言 输入10个学生5门功课成绩求:1每个学生的平均分;2每门功课的平均分;3计算平均方差

C语言用函数算数组的平均数和方差.如何编写

如何用C++或C编写求MAX,MIN,平均值,均方差

C语言利用函数调用求一组数的最大值,最小值,平均数。。。。。。急。。。。