比赛地址

A(暴力)

题目链接

题目:

给出\(K\),求出满足\(A\times B\times C\le K\)的\((A,B,C)\)对数

解析:

将C移动到等式右边,得到\(A\times B\le\frac{K}{C}\),对于\(t=\lfloor\frac{K}{C}\rfloor\),统计\(t\)向下整除\(1\sim t\)的和即为结果

#include<bits/stdc++.h>
using namespace std;
/*===========================================*/ int main() {
int k;
LL result = 0;
scanf("%d", &k);
for (int i = 1; i <= k; ++i) {
int end = k / i;
for (int j = 1; j <= end; ++j)
result += k / i / j;
}
printf("%lld", result);
}

B(思维)

题目链接

题目:

求出\(A^{B^C}\)的个位数字

解析:

不难得到以下循环

  1. 1 1 1 1 1 ...(1)
  2. 2 4 8 6 2 ...(4)
  3. 3 9 7 1 3 ...(4)
  4. 4 6 4 6 4 ...(2)
  5. 5 5 5 5 5 ...(1)
  6. 6 6 6 6 6 ...(1)
  7. 7 9 3 1 7 ...(4)
  8. 8 4 2 6 8 ...(4)
  9. 9 1 9 1 9 ...(2)
  10. 0 0 0 0 0 ...(1)
  • 对于循环长度为1,则直接输出本身
  • 循环长度为2,则考虑\(B\)奇偶性(奇数的幂还是奇数,偶数的幂还是偶数)
  • 循环长度为4分\(B\)的奇偶讨论
    • 如果\(B\)为奇数且模4为1,则他的幂模4还是1,否则模值在3 1循环
    • 如果为偶数则一定含有2,如果能被4整除则幂数模4一定是0,否则看2(因子)的出现次数,即幂数是否大于1,比1大模值为0,比一小模值1
#include<bits/stdc++.h>
using namespace std;
/*===========================================*/ map<int, map<int, int>> m;
int main() {
int a, b, c;
scanf("%d%d%d", &a, &b, &c);
m[4][0] = 4, m[4][1] = 6;
m[9][0] = 9, m[9][1] = 1;
m[2][0] = 2, m[2][1] = 4, m[2][2] = 8, m[2][3] = 6;
m[3][0] = 3, m[3][1] = 9, m[3][2] = 7, m[3][3] = 1;
m[8][0] = 8, m[8][1] = 4, m[8][2] = 2, m[8][3] = 6;
m[7][0] = 7, m[7][1] = 9, m[7][2] = 3, m[7][3] = 1;
a %= 10;
if (a == 0 || a == 1 || a == 5 || a == 6)
printf("%d", a);
else if (a == 4 || a == 9)
printf("%d", m[a][b % 2 == 0]);
else {
if (b & 1) {
if (b % 4 == 1)
printf("%d", m[a][0]);
else {
if (c & 1)
printf("%d", m[a][2]);
else
printf("%d", m[a][0]);
}
}
else {
if (b % 4 == 0)
printf("%d", m[a][3]);
else {
if (c >= 2)
printf("%d", m[a][3]);
else
printf("%d", m[a][1]);
}
}
}
}

C(贪心)

题目链接

题目:

给出一个字符串,以及操作:如果\(s_i=s_{i+1}\ne s_{i+2}\),则将\(s_{i+2}\)替换成\(s_i\),询问最多操作次数

解析:

那如果又两个连续的字符\(c\),则后序字符肯定能都变成\(c\),那么可以考虑从后向前进行替换,这样可以保证最大次数

如此则需要从前向后统计第一次出现的某字符\(c\)与下一个和他不一样的连续字符\(c'\)之间存在多少个\(c\)(这些字符不可以被操作需要从答案中减去),后序字符都可以被替换,因为操作时从后向前,后序字符均会被替换成\(c'\)

#include<bits/stdc++.h>
typedef long long LL;
using namespace std;
/*===========================================*/ const int maxn = 2e5 + 5;
char str[maxn]; int main() {
scanf("%s", str);
int len = strlen(str);
char last = 1;
int lpos = -1;
LL ret = 0;
for (int i = 0; i <= len; ++i) {
if (str[i] == str[i + 1] && str[i] != last)
{
if (~lpos)
ret += 1LL * len - lpos;
lpos = i;
last = str[i];
}
if (str[i] == last)
--ret;
}
printf("%lld", ret + 1);
}

D(排列组合+快速幂)

题目链接

题目:

给出\(n,m,k\),规定\(A_i\)为第\(i\)行最小的数字,\(B_i\)为第\(i\)行最大的数字,则有多少种序列的可能性(答案取模998244353)

解析:

  1. 要保证\(A\)中的最大值一定得小于等于\(B\)中最小值,因为假设A中最大值对应位置为\((i,j)\),则在第\(j\)列的最大值要大于等于\(i\)不可能小于$i
  2. 所以可以枚举\(i\),即\(pow(i,n)\times pow(k+1-i,m)\),但是这样的情况下对于左边(或者右边)可能出现包含的情况,所以一定要保证\(i\)在序列中至少出现1次(或者保证\(j\))
\[\sum_{i=1}^k(i^n-(i-1)^n)*(k-i+1)^m \ \%mod
\]

注意:

考虑\(n==1||m==1\)的特殊情况

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int mod = 998244353;
LL pw(LL n, int x) {
LL ret = 1;
LL t = n;
while (x) {
if (x & 1) ret = ret * t % mod;
t = t * t % mod;
x >>= 1;
}
return ret;
} int main() {
int n, m, k;
scanf("%d%d%d", &n, &m, &k);
if (n == 1)
printf("%lld", pw(k, m));
else if (m == 1)
printf("%lld", pw(k, n));
else {
LL ret = 0;
for (int i = 1; i <= k; ++i)
ret = ((pw(i, n) - pw(i - 1, n) + mod) % mod * pw(k + 1 - i, m) % mod + ret) % mod;
printf("%lld", ret);
}
}

AtCoder Regular Contest 113的更多相关文章

  1. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  2. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  3. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  4. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

  5. AtCoder Regular Contest 094

    AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...

  6. AtCoder Regular Contest 095

    AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...

  7. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

  8. AtCoder Regular Contest 096

    AtCoder Regular Contest 096 C - Many Medians 题意: 有A,B两种匹萨和三种购买方案,买一个A,买一个B,买半个A和半个B,花费分别为a,b,c. 求买X个 ...

  9. AtCoder Regular Contest 097

    AtCoder Regular Contest 097 C - K-th Substring 题意: 求一个长度小于等于5000的字符串的第K小子串,相同子串算一个. K<=5. 分析: 一眼看 ...

随机推荐

  1. (19)ln命令:在文件之间建立链接(硬链接和软链接)

    1.ext 文件系统(Linux 文件系统)是如何工作的. 我们在前面讲解了分区的格式化就是写入文件系统,而 Linux 目前使用的是 ext4 文件系统.如果用一张示意图来描述 ext4 文件系统 ...

  2. TCP/IP__Cisco的3层分层模型

    1. Cisco的层次模型:3个层次和它们的典型功能 核心层:骨干 分配层:路由 接入层:交换 核心层 1. 核心层就是网络的核心.它位于顶层,负责可靠而迅速地传输大量的数据流.网络核心层的唯一意图是 ...

  3. 四十五:漏洞发现-API接口服务之漏洞探针类型利用修复

    接口服务类安全测试 根据前期信息收集针对目标端口服务类探针后进行的安全测试,主要涉及攻击方法:口令安全,WEB类漏洞,版本漏洞等,其中产生的危害可大可小,属于端口服务/第三方服务类安全测试.一般在已知 ...

  4. js实现购物车左滑删除

    使用 js 和jquery动画实现购物车左滑,请引入jquery库,不然会报错哦! 首页编写页面,注意布局,滑动分成两部分,商品图片和信息放在一个布局,删除和移入收藏放在一起. 其中js用到了 tou ...

  5. AcWing 241 楼兰图腾 (树状数组)

    在完成了分配任务之后,西部314来到了楼兰古城的西部. 相传很久以前这片土地上(比楼兰古城还早)生活着两个部落,一个部落崇拜尖刀('V'),一个部落崇拜铁锹('∧'),他们分别用V和∧的形状来代表各自 ...

  6. Codeforces Round #171 (Div. 2) B. Books (模拟队列)

    题意:有一组数,问子数组和最大不超过\(t\)的最多元素个数. 题解:用数组模拟队列,不断的往里面放,队列中的元素之和大于\(t\),就不断地从队头弹出直到满足条件,维护一个最大值即可. 代码: in ...

  7. Codeforces Round #479 (Div. 3) D. Divide by three, multiply by two (DFS)

    题意:给你一个长度为\(n\)的序列\(a\).对它重新排列,使得\(a_{i+1}=a_{i}/3\)或\(a_{i+1}=2*a_{i}\).输出重新排列后的序列. 题解:经典DFS,遍历这个序列 ...

  8. 最新版gradle安装使用简介

    目录 简介 安装gradle和解决gradle安装的问题 Gradle特性 标准task Build phases Gradle Wrapper wrapper的使用 wrapper的升级 一个简单的 ...

  9. C# 网络流

    流(stream)是对串行传输的数据的一种抽象表示,底层的设备可以是文件.外部设备.主存.网络套接字等等. 流有三种基本的操作:写入.读取和查找. 如果数据从内存缓冲区传输到外部源,这样的流叫作&qu ...

  10. TextCNN代码实践

    在上文<TextCNN论文解读>中已经介绍了TextCNN的原理,本文通过tf2.0来做代码实践. 数据集:来自中文任务基准测评的数据集IFLYTEK 导库 import os impor ...