xz2945624632 2022-02-23 14:01 采纳率: 50%
浏览 43
已结题

求c语言解决相关问题

是这样,有一个大城市,包括N个街道(镇),每个小时会统计一次街道内某种目标人群的样本数量(X),人群数量用手机定位统计,会随着早晚高峰或者夜间波动我现在需要:把当天平均强度前5%的街道筛选出来,需要一个数学表达式(1)把当天波动幅度(街道人数高峰小时/最低谷小时)最大的前5%街道筛选出来,需要一个表达式(2)然后,5年后再做一次统计,将平均强度变化程度前5%的街道少选 出来,需要一个表达式(3)

  • 写回答

2条回答 默认 最新

  • 关注

    用数组保存没条街道的数据,统计当天的最大值和最小值,然后计算波动,用波动排序,输入前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;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 创建了问题 2月23日

悬赏问题

  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)