求c语言解决相关问题

是这样,有一个大城市,包括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;
}

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632