当前位置: 首页 > news >正文

实验室网站建设方案如何制作自己的二维码

实验室网站建设方案,如何制作自己的二维码,建设网站用什么,小游戏代码编程统计每个元素出现的次数,直接计算元素在有序序列中的位置,要求数据是整数且范围有限。适用于数据为小范围整数(如年龄、成绩),数据重复率较高时效率更优。可用于小范围整数排序、基数排序的底层排序(作为基数排序的稳定…

统计每个元素出现的次数,直接计算元素在有序序列中的位置,要求数据是整数且范围有限。适用于数据为小范围整数(如年龄、成绩),数据重复率较高时效率更优。可用于小范围整数排序、基数排序的底层排序(作为基数排序的稳定排序子过程)、统计频率分布(快速获取元素分布直方图)、海量数据预处理(配合外部排序处理大数据文件)

#include <stdlib.h>
#include <assert.h>// 计数排序核心函数(稳定排序版本)
void countingSort(int arr[], int n) {if (n <= 1) return; // 无需排序// 1. 确定数据范围int max = arr[0], min = arr[0];for (int i = 1; i < n; i++) {if (arr[i] > max) max = arr[i];if (arr[i] < min) min = arr[i];}const int range = max - min + 1; // 实际数值范围// 2. 创建计数数组并初始化int* count = (int*)calloc(range, sizeof(int));assert(count != NULL);// 3. 统计每个元素出现次数for (int i = 0; i < n; i++) {count[arr[i] - min]++; // 偏移处理负数}// 4. 计算累计位置(保证稳定性)for (int i = 1; i < range; i++) {count[i] += count[i - 1];}// 5. 反向填充结果数组(关键稳定性操作)int* output = (int*)malloc(n * sizeof(int));assert(output != NULL);for (int i = n - 1; i >= 0; i--) {output[count[arr[i] - min] - 1] = arr[i];count[arr[i] - min]--;}// 6. 复制回原数组for (int i = 0; i < n; i++) {arr[i] = output[i];}// 7. 释放内存free(count);free(output);
}
#include <stdio.h>
// 打印数组
void printArray(int arr[], int size) {for (int i = 0; i < size; i++) {printf("%d ", arr[i]);}printf("\n");
}int main() {// 测试数据(包含负数)int arr[] = {-5, 2, -3, 4, 1, 2, 8, 5, 3, -1};int n = sizeof(arr) / sizeof(arr[0]);printf("排序前: ");printArray(arr, n);countingSort(arr, n);printf("排序后: ");printArray(arr, n);return 0;
}

优化建议:

1.通过min值偏移处理负数,支持全整数范围排序

2.通过反向遍历填充输出数组,保留相同元素的原始顺序,已保证稳定性

3.动态计算range值,避免不必要的内存浪费

void countingSortSpaceOptimized(int arr[], int n) {// ...(省略范围计算步骤)...// 直接根据计数数组覆盖原数组(非稳定)int idx = 0;for (int i = 0; i < range; i++) {while (count[i]-- > 0) {arr[idx++] = i + min;}}
}

http://www.yayakq.cn/news/831187/

相关文章:

  • 星子县网站建站公司想找可以在家做的手工活去什么网站
  • discuz做电影网站宿州做网站公司
  • 商城网站建设预算要多少钱大学做视频网站
  • 建设好网站网站标题第一个词
  • 如何优化网站目录结构两学一做教育网站
  • 淘客的手机网站wordpress采集网址
  • 国际站wap端流量广州知名网站设计
  • 建设一个门户网站价格wordpress教程 下载地址
  • asp做网站策划书网上代做论文的网站
  • 《学做网站论坛》视频下载外贸圈的尖子生
  • nodejs网站开发实例顺德大良做网站
  • 移动网站搭建wordpress 投稿
  • 宝格丽网站建设策划案物联网平台软件开发
  • 邢台市做网站网站优化关键词排名自己怎么做
  • 小鱼儿外贸建站网站建设与网络编辑综合实训课程指导手册pdf
  • 余姚做网站濮阳信息港网首页
  • 做网站怎么变现禄劝彝族苗族网站建设
  • 如何做网站内容架构分析北京自考网官方网站
  • 贵州微信网站建设手机wordpress主题
  • 婚恋网站如何做推广用主机宝建立的网站上传之后404
  • 网站侧边栏导航代码用html5做的静态网站
  • 企业网站建设论坛网站网页制作及优化
  • 芜湖小学网站建设新网站怎么做seo
  • 网站建设许可证网站首页被k咋办
  • 电商网站开发设计方法cpanel做wordpress
  • 企业网站宣传方案建设银行 福建分行招聘网站
  • 漳州网站建设哪家最权威做网站多大
  • 石景山富阳网站建设saas电商平台
  • 常州本地网站网站建设方面的书籍
  • 检查网站的死链接wordpress纯静态化插件