牛客网NOIP赛前集训营-普及组(第二场)

题目链接:https://www.nowcoder.com/acm/contest/165#question

A 你好诶加币

设最大值为maxx,最小值为minn

分三种情况:

\(1.a > 0 且b > 0\)

会加爆long long,所以化简式子

\(maxx - a >= b\)

\(2.a < 0 且b < 0\)

会加爆long long,所以化简式子

\(minn - b <= a\)

\(3.剩下的情况\)

直接输出yes

CODE

#include <iostream>
#include <cstdio>
#define ll long long ll maxx = 9223372036854775807,minn = -9223372036854775808; bool calc(ll a,ll b) {
if(a > 0 && b > 0) {
if(maxx - b < a) return false;
return true;
}
if(a < 0 && b < 0)
if(minn - b <= a) return false;
return true;
}
return true;
} int main() {
std::cin >> a >> b;
if(calc(a,b)) {
std::cout << a + b;
}
else puts("\"hello, %lld\\n\"");
return 0;
}

B 最后一次

直接从n往低处枚举\(\sqrt{i}\)判断素数即可.

因为素数的密度大概在\(1 / ln n\)

所以期望\(logn\)左右.

所以不会超时.

CODE

#include <iostream>
#include <cstdio>
#include <cmath>
#define ll long long bool calc(ll x) {
ll q = sqrt(x);
for(int i = 2;i <= q;++ i) {
if(x % i == 0) return false;
}
return true;
} int main() {
ll n;
std::cin >> n;
for(ll i = n;i >= 2;-- i) {
if(calc(i)) {
std::cout << i;
return 0;
}
}
return 0;
}

C 选择颜色

结论题吧,即使在考试中看出组合+奇偶讨论一下,但是当时时间不够..

日后再做也还是不会做.

直接放结论吧.

\((c-1)^n +(c-1)*-1^n\)

当然也可反向推递推式.

\(f(n)=(c-2)*f(n-1) + (c-1)*f(n-2)\)

这个博主讲解的非常好,不过式子有问题,正确的式子应该是上面这个.

然后用矩阵快速幂求.

CODE

#include<cstdio>
#include<iostream>
using namespace std;
int fastpow(int a, int p,int mod)
{
int base = 1;
while(p)
{
if(p & 1)base = (base * a) % mod;
a = (a * a) % mod; p >>= 1;
}
return base;
}
int main()
{
int n,c,p;
cin >> n >> c;
p = 10007;
int ans;
cout << fastpow(c - 1, n, p) + (c - 1) * fastpow(-1, n, p);
return 0;
}

D 合法括号序列

DP,暂时不想做.放到以后做.

牛客网NOIP赛前集训营-提高组(第二场)

题目链接:https://www.nowcoder.com/acm/contest/173#question

A 方差

化简式子,不能出现除的形式,不然会有精度问题.

\[m^2\dfrac{1}{m}\ast\sum_i^m(b_i-\overline{b})^2
\]

\[m\ast\sum_i^m(b_i-\overline{b})^2
\]

\[m\ast\sum_i^m{b_i}^2 - 2 \ast b_i \overline{b} + \overline{b}^2
\]

拆开.

\[m*({b_1}^2 + {b_2}^2 + {b_3}^2 + ...{b_m}^2) - 2*m* \overline{b}\ast (b_1+b_2+b_3+....b_m) + m^2*\overline{b}
\]

设\(sum\)为\(b_1+b_2+...b_m\)

折\(sum2\)为\({b_1}^2 + {b_2}^2 + {b_3}^2 + ...{b_m}^2\)

则\(\overline{b} = \dfrac{sum}{m}\)

带入

\(m * sum2 - 2 * sum^2+ sum^2\)

\(m * sum2 - sum ^ 2\)

其中先算出\(sum = b_1+b_2+....b_n\)

然后直接减去那个值就好.

sum2同理

那么时间复杂度就是\(O(n)\)的

#include <iostream>
#include <cstdio>
#define ll long long
const int maxN = 1e5 + 7; int n;
ll a[maxN];
ll sum1,sum2; inline ll read() {
ll x = 0,f = 1;char c = getchar();
while(c < '0' || c > '9') {if(c == '-')f = -1;c = getchar();}
while(c >= '0' && c <= '9') {x = x * 10 + c - '0';c = getchar();}
return x * f;
} int main() {
scanf("%d",&n);
int m = n - 1;
for(int i = 1;i <= n;++ i)
a[i] = read();
for(int i = 1;i <= n;++ i) {
sum1 += a[i];
sum2 += a[i] * a[i];
}
for(int i = 1;i < n;++ i)
printf("%lld ", (ll)m * (sum2 - a[i] * a[i]) - (sum1 - a[i]) * (sum1 - a[i]));
printf("%lld\n", (ll)m * (sum2 - a[n] * a[n]) - (sum1 - a[n]) * (sum1 - a[n]));
}

B 分糖果

不会,但是部分分就是,当所有的\(a_i\)相等时,就成了PJ组的C题.

\(n≤4\)直接dfs.

\(n <= 100, a_i <= 20\)

\(n <= 100, a_i <= 100\)

这部分数据就是DP.

我不会.

放20分的吧.

#include <iostream>
#include <cstdio>
#define ll long long
using namespace std;
const int mod = 1e9 + 7;
const int maxN = 1e6 + 7; int n;
int a[maxN];
int b[maxN];
int cnt; inline int read() {
int x = 0,f = 1;char c = getchar();
while(c < '0' || c > '9') {if(c == '-') f = -1;c = getchar();}
while(c >= '0' && c <= '9') {x = x * 10 + c - '0';c = getchar();}
return x * f;
} ll power(ll a,int b)
{
ll ans = 1;
for(ll now = a;b;b >>= 1,now = now * now % mod) {
if(b & 1) ans = ans * now % mod;
}
return ans % mod;
} void dfs(int now) {
if(now == n + 1) {
if(b[1] != b[n]) cnt ++;
return;
}
for(int i = 1;i <= a[now];++ i) {
b[now] = i;
if(b[now] != b[now - 1])
dfs(now + 1);
}
return ;
} int main()
{
scanf("%d",&n);
for(int i = 1;i <= n;++ i) {
a[i] = read();
}
dfs(1);
cout << cnt;
return 0;
}

C 集合划分

神仙题目,弃疗.

牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告的更多相关文章

  1. 牛客网NOIP赛前集训营-提高组(第四场)游记

    牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...

  2. 牛客网NOIP赛前集训营-提高组(第四场)B区间

    牛客网NOIP赛前集训营-提高组(第四场)B区间 题目描述 给出一个序列$ a_1  \dots   a_n$. 定义一个区间 \([l,r]\) 是好的,当且仅当这个区间中存在一个 \(i\),使得 ...

  3. 牛客网NOIP赛前集训营-提高组(第四场)B题 区间

    牛客网NOIP赛前集训营-提高组(第四场) 题目描述 给出一个序列 a1, ..., an. 定义一个区间 [l,r] 是好的,当且仅当这个区间中存在一个 i,使得 ai 恰好等于 al, al+1, ...

  4. 牛客网CSP-S提高组赛前集训营Round4

    牛客网CSP-S提高组赛前集训营 标签(空格分隔): 题解 算法 模拟赛 题目 描述 做法 \(BSOJ6377\) 求由\(n\)长度的数组复制\(k\)次的数组里每个连续子序列出现数字种类的和 对 ...

  5. 牛客CSP-S提高组赛前集训营1

    牛客CSP-S提高组赛前集训营1 比赛链接 官方题解 before:T1观察+结论题,T2树形Dp,可以换根或up&down,T3正解妙,转化为图上问题.题目质量不错,但数据太水了~. A-仓 ...

  6. 牛客NOIP暑期七天营-提高组5+普及组5

    ————提高组———— 第一题:deco的abs 题目链接:https://ac.nowcoder.com/acm/contest/934/A 因为每个数都可以加任意次 d ,所以可以推出 0 < ...

  7. 牛客NOIP暑期七天营-提高组1

    牛客NOIP暑期七天营-提高组1 链接 A 边权可为0就排序建一条链子. 但是边权不为0 除了第一个有0的不行. x连向上一个比他小的数. 期间判断有无解. #include <bits/std ...

  8. 18/9/16牛客网提高组Day2

    牛客网提高组Day2 T1 方差 第一眼看就知道要打暴力啊,然而并没有想到去化简式子... 可能因为昨晚没睡好,今天上午困死 导致暴力打了一个半小时,还不对... #include <algor ...

  9. 18/9/9牛客网提高组Day1

    牛客网提高组Day1 T1 中位数 这好像是主席树??听说过,不会啊... 最后只打了个暴力,可能是n2logn? 只过了前30%  qwq #include<algorithm> #in ...

随机推荐

  1. 阿里mavne中央仓库

    https://www.cnblogs.com/ae6623/p/4416256.html 待整理

  2. 网络编程WebSocket 和socket、HTTP的区别和联系

    一.WebSocket 是什么? WebSocket是HTML5规范提出的一种协议:目前除了完犊子的IE浏览器,其他浏览器都基本支持.他是一种协议,万变不离其宗,也是基于TCP协议的:和HTTP协议是 ...

  3. 抛出异常-throws和throw

    package com.mpp.test; import java.util.Scanner; public class TryDemoFour { public static void main(S ...

  4. 洛谷 P1094 纪念品分组

    P1094 纪念品分组 先按价格对纪念品排序(这里是从大到小),然后从两端向中心开始配对,有两个变量i和j,表示正在处理的两个纪念品编号,开始时i=1,j=n,如果a[i]+a[j]>w则第i贵 ...

  5. [已读]JavaScript DOM编程艺术

    看到过很多人将它作为推荐入门书籍,当时我刚看完ppk和javascript精粹,于是看到这本就觉得很一般了.怎么说,它适合基础.

  6. Redis基础理论

    一.概述 二.数据类型 STRING LIST SET HASH ZSET 三.数据结构 字典 跳跃表 四.使用场景 计数器 缓存 查找表 消息队列 会话缓存 分布式锁实现 其它 五.Redis 与 ...

  7. awk一些简单命令

    最简单地说, AWK 是一种用于处理文本的编程语言工具.AWK 在很多方面类似于 shell 编程语言,尽管 AWK 具有完全属于其本身的语法. 尽管操作可能会很复杂,但命令的语法始终是: awk ' ...

  8. jasmine+karma 自动化单元测试

    测试的必须性 相信大家都知道测试的必要性,测试先行的概念.不过,写了这么多年的代码,除了之前用java的时候写过一些测试用例,还真的很少写过前端的测试用例,或者做一些自动化测试.感觉做单元测试还是很有 ...

  9. springBoot + mybatis实现执行多条sql语句出错解决方法

    在Idea中执行多条sql语句的修改(mybatis默认的是执行sql语句是执行单条,所以要执行多条的时候需要进行配置) 需要在连接字符串中添加上&allowMultiQueries=true ...

  10. 一些JS基本小内容

    获取select选中内容: 1.获取select表单内容 <select id="sel"> <option value="v1">1& ...