oranoos_mta
New Member
میخوام برنامه ای بنویسم که n عدد double را از ورودی بگیرد و پس از مرتب کردن مجموع m عدد میانی را بدست بیاورد
m را نیز از ورودی میگیرد
من اینو نوشتم ولی مشکل داره میشه کمکم کنید
m را نیز از ورودی میگیرد
من اینو نوشتم ولی مشکل داره میشه کمکم کنید
کد:
#include <stdio.h>
#include <math.h>
#include <iostream.h>
void out(double m[],int n)
{
int i;
for(i=0;i<n;i++)
cout<<" "<<m[i];
}
void sort(double *y,int n)
{
int i,temp;
for(i=n-1;i>0;i--)
{
for (int j=0; j<i; j++)
if(y[j+1]<y[j])
{
temp=y[j];
y[j]=y[j+1];
y[j+1]=temp;
}
}
}
void main()
{
int n,k;
cout<<"enter n : ";
cin>>n;
double *m;
m=new double[n];
for (int i=0; i<n; i++)
{
cout<<"enter m["<<(i+1)<<"] : ";
cout.flush();
cin>>m[i];
}
sort(m,n);
out(m,n);
cout<<endl;
cout<<"enter a number as low as "<<n<<" ---> ";
cin>>k;
if (k>=n)
cout<<"invalid your number"<<endl;
int t=1; int p=0; int sum=0;
while(p<k)
{
if (k<=2)
{
sum=sum+m[(n/2)+t];
break;
}
sum=sum+m[(n/2)+t];
t*=-1;
sum=sum+m[(n/2)+t];
t++; p+=3;
}
sum=sum+m[n/2];
cout<<"plus center digits of your array--->"<<sum;
delete []m;
}