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

英语网站的建设需要关于进一步优化

英语网站的建设需要,关于进一步优化,做网站找哪家,无锡网站建设方案维护离散化 在C中,离散化通常指的是将连续的数值或数据转化为离散的形式。这在数值分析、信号处理、图像处理和机器学习等领域都非常常见。以下是一些离散化的基本概念和方法: 1.区间划分: 将连续变量的值域分成多个区间,每个区间对…

离散化

在C++中,离散化通常指的是将连续的数值或数据转化为离散的形式。这在数值分析、信号处理、图像处理和机器学习等领域都非常常见。以下是一些离散化的基本概念和方法:

1.区间划分:

将连续变量的值域分成多个区间,每个区间对应一个离散的值。例如,将浮点数分成若干个区间,可以用区间的中点、边界或其他代表值来替代该区间内的所有值。

2.量化:

在信号处理中,量化是将连续信号转换为离散信号的过程。可以使用固定点数表示或浮点数表示。

3.

插值与样本选择:在离散化过程中,可以通过插值技术生成离散样本,或选择数据集中的特定样本点。
在这里插入图片描述
前缀和算法
二分查找

我们来看一道题可以帮助我们更好的理解这个算法

在这里插入图片描述
Acwing804.区间和
我们举个例子:
在这里插入图片描述
我们现在根据题来看,题中是进行了3次读操作3次写操作。
在这里插入图片描述

代码如下:

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;const int N = 300010;
int n, m;        // n 表示插入操作的数量,m 表示查询操作的数量
int a[N];        // 用于存储每个离散化后位置的值
int s[N];        // 前缀和数组
vector<int> alls; // 用于存储所有需要离散化的坐标
vector<pair<int, int>> add, query; // 分别存储插入操作和查询操作// 二分查找,找到 x 在 alls 中对应的位置(离散化)
int find(int x)
{int l = 0, r = alls.size() - 1;while (l < r){int mid = l + r >> 1;if (alls[mid] >= x)  // 如果中间值大于等于 x,右边界缩小r = mid;else                 // 否则左边界增大l = mid + 1;}return r + 1;  // 返回离散化后的索引(从 1 开始)
}int main()
{// 读取插入操作和查询操作cin >> n >> m;for (int i = 1; i <= n; i++){int x, c;cin >> x >> c;alls.push_back(x);          // 收集需要离散化的 x 坐标add.push_back({x, c});      // 保存插入操作}  for (int i = 1; i <= m; i++){int l, r;cin >> l >> r;alls.push_back(l);          // 收集查询范围的左端点alls.push_back(r);          // 收集查询范围的右端点query.push_back({l, r});    // 保存查询操作}// 去重并排序,完成离散化准备sort(alls.begin(), alls.end());                          // 将所有的坐标排序alls.erase(unique(alls.begin(), alls.end()), alls.end()); // 去重/*unique 函数用于 移除相邻的重复元素,它并不真正删除元素,而是将重复的元素移动到容器的末尾部分,函数返回一个迭代器,该迭代器指向新容器末尾的下一个位置(即去重后第一个“无效”元素的位置)。前提条件:为了让 unique 正确工作,输入的容器必须是有序的,即相等的元素必须相邻。因此,在调用 unique 之前,通常要先对容器进行排序(sort)。alls.begin() 是 alls 数组的起始位置。alls.end() 是 alls 数组的末尾位置(不包括最后一个元素)。unique(alls.begin(), alls.end()) 将相邻的重复元素移动到容器末尾,并返回一个新的迭代器 new_end,该迭代器指向去重后有效数据的末尾。*/// 处理插入操作for (auto item : add){int x = find(item.first); // 找到 x 在离散化后的索引a[x] += item.second;      // 在离散化后的位置上加上对应的值}// 计算前缀和for (int i = 1; i <= alls.size(); i++){s[i] = s[i - 1] + a[i];  // 通过累加前缀和数组得到区间的和}// 处理查询操作for (auto item : query){int l = find(item.first);  // 找到 l 在离散化后的索引int r = find(item.second); // 找到 r 在离散化后的索引cout << s[r] - s[l - 1] << endl; // 输出区间 [l, r] 的和,并换行}return 0;
}

离散化代码源码

http://www.yidumall.com/news/37192.html

相关文章:

  • 深圳石岩网站建设网络推广吧
  • html5和css3制作个人网站源码下载百度地图2022最新版官方
  • 网站 租用服务器网络营销是什么?
  • 网站怎么加代码chatgpt 链接
  • 手机上怎么做自己卖菜的网站我的百度账号
  • 深圳网站建设忧化2345网址导航官方网站
  • 程序员接活的平台网站站长工具seo客户端
  • 做图的ppt模板下载网站平台接广告在哪里接的
  • 网站建设 甲方欠款 如何处理营销软文范例500
  • 宿州网站建设成人电脑速成培训班
  • 网站备案前置审批辽阳网站seo
  • 博客型网站建设少儿编程
  • ppt做会动彩字网站小学生抄写新闻20字
  • 汽车网站建设公司哪家好2021年搜索引擎排名
  • 素材网站免费短视频seo大全
  • 交互效果好的移动端网站潮州seo
  • 怎么修改wordpress目录名字郑州seo网站排名
  • 怎么做网站的图片近10天的时政新闻
  • 17来做网站网络营销服务的特点有哪些
  • 旅游网站如何做推广爱网
  • 正规网络游戏平台河南seo优化
  • 做网站大概需要多少钱郑州百度推广公司电话
  • 网站建设公司的业务范围seo每日
  • 个人网站如何制作域名注册阿里云
  • win7主机做网站电脑培训班速成班
  • 高安网站制作5188关键词平台
  • iis 网站访问权限设置培训机构哪家最好
  • 网站建设的规划方案衡阳seo外包
  • wordpress图片云盘温州seo优化公司
  • 小学生手工制作关键词优化分析工具