是这样,有一个大城市,包括N个街道(镇),每个小时会统计一次街道内某种目标人群的样本数量(X),人群数量用手机定位统计,会随着早晚高峰或者夜间波动我现在需要:把当天平均强度前5%的街道筛选出来,需要一个数学表达式(1)把当天波动幅度(街道人数高峰小时/最低谷小时)最大的前5%街道筛选出来,需要一个表达式(2)然后,5年后再做一次统计,将平均强度变化程度前5%的街道少选 出来,需要一个表达式(3)
2条回答 默认 最新
- 技术专家团-小桥流水 2022-02-23 15:31关注
用数组保存没条街道的数据,统计当天的最大值和最小值,然后计算波动,用波动排序,输入前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无用
悬赏问题
- ¥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 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)