是这样,有一个大城市,包括N个街道(镇),每个小时会统计一次街道内某种目标人群的样本数量(X),人群数量用手机定位统计,会随着早晚高峰或者夜间波动我现在需要:把当天平均强度前5%的街道筛选出来,需要一个数学表达式(1)把当天波动幅度(街道人数高峰小时/最低谷小时)最大的前5%街道筛选出来,需要一个表达式(2)然后,5年后再做一次统计,将平均强度变化程度前5%的街道少选 出来,需要一个表达式(3)
用数组保存没条街道的数据,统计当天的最大值和最小值,然后计算波动,用波动排序,输入前5%的街道即可。
假设N个街道从1-N编号,输出前5%的街道编号及其波动幅度,代码如下:
#include <stdio.h>
#include <stdlib.h>
//冒泡排序
void bubble_sort(double a[],int index[],int n)
{
int i,j,ins;
double t;
for (i=0;i<n-1;i++)
{
for (j=0;j<n-1-i;j++)
{
if(a[j] < a[j+1]) //从大到小排序
{
//交换数据位置
t = a[j];
a[j]=a[j+1];
a[j+1]=t;
//交换下标,下标随数据变化
ins = index[j];
index[j] = index[j+1];
index[j+1] = ins;
}
}
}
}
int main()
{
int **data,n,i,j,max,min;
double *bd;
int* index;
int nmb;
printf("请输入街道数:");
scanf("%d",&n);
//申请空间,保存n条街道某天的所有数据
data = (int **)malloc(sizeof(int*)*n);
bd = (double *)malloc(sizeof(double)*n); //保存每条街的波动
index = (int*)malloc(sizeof(int)*n); //记录每条街的索引,以便后面输出街道编号,街道编号按照输入顺序设为1-N
//获取当天的数据
for(j=0;j<n;j++)
{
data[j] = (int*)malloc(sizeof(int)*24);
printf("请输入第%d条街的24小时数据:\n",j+1);
for(i=0;i<24;i++)
{
scanf("%d",&data[j][i]);
//得到第j+1条街24小时波动幅度的最大值和最小值
if(i==0)
{
max = data[j][i];
min = data[j][i];
}else
{
if(data[j][i] > max) max = data[j][i];
if(data[j][i] < min) min = data[j][i];
}
}
//计算波动
bd[j] = (double)max/min;
//索引
index[j] = j+1; //记录街道的编号(假设街道从1-n编号)
}
//对所有的波动进行排序
bubble_sort(bd,index,n);
nmb = n*0.05; //找波动最大的前5%
printf("波动前5%的街道编号及波动信息为:\n");
for(i=0;i<nmb;i++)
{
printf("第%d条街道,波动:\n",index[i],bd[i]);
}
//释放空间
free(bd);
bd = 0;
free(index);
index=0;
for(i=0;i<n;i++)
{
free(data[i]);
data[i]=0;
}
free(data);
data = 0;
return 0;
}
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!