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

旅游景点网站建设规划书产品推广运营方案

旅游景点网站建设规划书,产品推广运营方案,3d建模用什么软件好,删除多余wordpress前端ACM- 其他算法 一、前缀和模板例题1、区间余数求K倍区间个数:AcWing 1230. K倍区间例题2、前缀和哈希求最长个数平分子串:Leetcode 面试题 17.05 字母与数字 二、差分1、一维差分2、二维差分 一、前缀和 模板 //一维前缀和 S[i] a[1] a[2] ... a[i] a[l] ... …

ACM- 其他算法

  • 一、前缀和
    • 模板
    • 例题1、区间余数求K倍区间个数:AcWing 1230. K倍区间
    • 例题2、前缀和+哈希求最长个数平分子串:Leetcode 面试题 17.05 字母与数字
  • 二、差分
    • 1、一维差分
    • 2、二维差分

一、前缀和

模板

//一维前缀和
S[i] = a[1] + a[2] + ... a[i]
a[l] + ... + a[r] = S[r] - S[l - 1]//二维前缀和
S[i, j] = 第i行j列格子左上部分所有元素的和
以(x1, y1)为左上角,(x2, y2)为右下角的子矩阵的和为:
S[x2, y2] - S[x1 - 1, y2] - S[x2, y1 - 1] + S[x1 - 1, y1 - 1]

例题1、区间余数求K倍区间个数:AcWing 1230. K倍区间

原题链接: https://www.acwing.com/problem/content/1232/

(原题来源: 第八届蓝桥杯省赛C++B组,第八届蓝桥杯省赛JAVAB组)
在这里插入图片描述

import java.util.Scanner;public class Main{public static int[] sum = new int[100010];  //前缀和取模后public static int[] cnt = new int[100010];  //个数public static void main(String[] args) {Scanner sc = new Scanner(System.in);int n = sc.nextInt();int k = sc.nextInt();long ans = 0;cnt[0] = 1;for (int i = 1; i <= n; ++ i) {sum[i] = sum[i - 1] + sc.nextInt(); //计算前缀和sum[i] %= k;  //求出k的整数次倍剩下的数ans += cnt[sum[i]];  //相当于减去前面的余数,得出以i为终点的合法子序列的种数++ cnt[sum[i]];     //更新}System.out.println(ans);}
}

例题2、前缀和+哈希求最长个数平分子串:Leetcode 面试题 17.05 字母与数字

原题链接:https://leetcode-cn.com/problems/find-longest-subarray-lcci/
在这里插入图片描述

思路

字母+1,数字-1,获得array的前缀和数组arr,同时记录和维护当前的sum的最远索引位置,比如对于A 1 A A 1 1 A 1 1 1 A 1 1 A,可以获得前缀和数组:1 0 1 2 1 0 1 0 -1 -2 -1.
我们可以发现对于第一个A来说,能和它匹配的最长子数组是最后一个0的位置.
以此类比,假如当前位置是字母,其前缀和为a,那么最远能匹配的位置一定是最远的前缀和为a-1的地方;
反之,假如当前位置是数字,其前缀和为a,那么最远能匹配的位置一定是最远的前缀和为a+1的地方.

class Solution {
public:static const int N = 100000;int book[N * 2 + 20], arr[N + 20];vector<string> findLongestSubarray(vector<string>& array) {int num = 0, length = array.size();for (int i = 0; i < length; ++ i) {if (isNum(array[i][0])) -- num;else ++ num;book[num + N] = i;arr[i] = num;}vector<string> ans;int maxx = 0, l = -1, r = -1;for (int i = 0; i < length; ++ i) {if (isNum(array[i][0])) { int a = book[N + arr[i] + 1];if (a > i && a - i > maxx) {maxx = a - i;l = i, r = a;}}else {int a = book[N + arr[i] - 1];if (a > i && a - i > maxx) {maxx = a - i;l = i, r = a;}}}if (maxx == 0) return ans;else {for (int i = l; i <= r; ++ i) {ans.push_back(array[i]);}return ans;}}bool isNum(char c) {return c >= '0' && c <= '9';}
};

二、差分

1、一维差分

AcWing 797. 差分

原题链接:https://www.acwing.com/problem/content/799/
在这里插入图片描述
差分定义

首先给定一个原数组a:a[1], a[2], a[3]……a[n];

然后我们构造一个数组b : b[1] ,b[2] , b[3]…… b[i];

使得 a[i] = b[1] + b[2 ]+ b[3] +…… + b[i]

也就是说,a数组是b数组的前缀和数组,反过来我们把b数组叫做a数组的差分数组。
换句话说,每一个a[i]都是b数组中从头开始的一段区间和。

解法

给区间[l, r]中的每个数加上c:B[l] += c, B[r + 1] -= c

代码

#include<bits/stdc++.h>using namespace std;const int N = 100010;//add为差分数组,表示当前位置的变化
int nums[N], add[N];int main() {int n, m;cin >> n >> m;for (int i = 1; i <= n; ++ i) cin >> nums[i];while (m --) {int l, r, c;cin >> l >> r >> c;add[l] += c;add[r + 1] -= c;}for (int i = 1; i <= n; ++ i) {add[i] += add[i - 1];nums[i] += add[i];cout << nums[i] << " ";}return 0;
}

2、二维差分

AcWing 798. 差分矩阵
原题链接:https://www.acwing.com/problem/content/800/
在这里插入图片描述
在这里插入图片描述
看代码应该就差不多了。

#include <bits/stdc++.h>using namespace std;const int N = 1010;int nums[N][N], add[N][N];  //add为差分矩阵void insert(int x1, int y1, int x2, int y2, int c) {add[x1][y1] += c;add[x1][y2 + 1] -= c;add[x2 + 1][y1] -= c;add[x2 + 1][y2 + 1] += c;
}int main() {int n, m, q;cin >> n >> m >> q;for (int i = 1; i <= n; ++ i) {for (int j = 1; j <= m; ++ j) {cin >> nums[i][j];}}while (q --) {int x1, y1, x2, y2, c;cin >> x1 >> y1 >> x2 >> y2 >> c;insert(x1, y1, x2, y2, c);}for (int i = 1; i <= n; ++ i) {for (int j = 1; j <= m; ++ j) {add[i][j] += add[i - 1][j] + add[i][j - 1] - add[i - 1][j - 1];nums[i][j] += add[i][j];cout << nums[i][j] << " ";}cout << endl;}return 0;
}
http://www.dinnco.com/news/50571.html

相关文章:

  • 赌博网站程序架设网页制作软件dw
  • 衡水企业网站设计报价百度一下百度官网
  • 南京明月建设集团网站西安网络优化大的公司
  • 网站制作网站模板网络营销策划的方法
  • 网站设置的用途安徽网站推广
  • 海口免费建站怎样打百度人工客服热线
  • 石家庄网站建设联系电话seo长尾关键词排名
  • 江苏住房和城乡建设委员会网站郑州厉害的seo顾问公司
  • 在哪个网站做网上兼职靠谱吗网站seo优化总结
  • 新手可以自己建网站吗谷歌google官网下载
  • 网站备案检验单北京seo人员
  • 易博彩票网站开发软文是什么文章
  • 做排版的网站开源crm系统
  • 做淘宝还是做网站容易口碑营销方案怎么写
  • 新兴网站建设seo推广方法有哪些
  • 杭州笕桥网站建设现在做网络推广都有什么方式
  • 做香港台湾网站流量成人职业技能培训学校
  • 网站制作的论文百度识图网页版 在线
  • 电 器建设网站目的及功能定位2023年8月份新冠症状
  • 绵阳市建设网招标公告珠海seo推广
  • 机械网站源码 php百度seo软件是做什么的
  • 做二手房网站怎么在百度发布免费广告
  • 网站怎么做qq客服广告投放推广平台
  • 网站怎么做推广今天国际新闻大事
  • 网站日志文件查看南京seo网站优化推广
  • 安徽柱石建设有限公司网站优化网站建设seo
  • wordpress书单广州seo服务外包
  • 网站设计专家百度搜索排名与点击有关吗
  • 域名备案要先做网站的吗广州软文推广公司
  • 个人音乐网站模板百度首页排名优化多少钱