2018/8/15 qbxt 测试

期望得分:100;实际得分:50   不知道为什么写挂了,明明是个水题 T^T

思路:模拟

注意:如果用 char 类型存储的话,如果有'z' + 9 会爆char  但是我明明用的 string 啊

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int n, m;
int len;
string s, ss; int main() {
scanf("%d%d", &n, &m);
cin >> s >> ss;
len = s.length();
for(int i = ; i < len; i++) {
s[i] += ss[i%m] - '';
if(s[i] > 'z') s[i] = s[i] - 'z' + 'a' - ;
}
cout << s << '\n';
return ;
}

考场代码

#include <cstdio>

#define next(i) ((i) == K-1 ? 0 : (i) + 1)

int main() {
int L, K;
scanf("%d%d", &L, &K);
char * s1 = new char[L + ];
char * s2 = new char[K + ]; scanf("%s%s", s1, s2); int j = ;
for (int i=; i<L; i++, j = (j==K- ? : j+))
s1[i] = ((s1[i] - 'a') + (s2[j] - '')) % + 'a'; puts(s1);
return ;
}

std

期望得分:100;实际得分:100

思路:将因为是完全平方数,所以这个数的因子在1~n中一定是出现了偶数次,道理显然,否则一定不会出现这样一个数。因此我们可以对于N分解质因数,用线性筛O(N)求出1~n的素数。求出素数后用N除以每个素数,开一个数组记录一下出现的次数,对于除出来的商,我们在判断一下能否在继续除以当前的素数,能继续除就继续加,道理显然。 
因此,如果数组中记录的数为奇数,就-1,这样就能保证以上偶数次的要求。

#include<iostream>
#include<cstdlib>
#include<cstdio>
#define LL long long
using namespace std;
const int maxn = ;
const LL mod = ;
bool not_prime[maxn];
int cnt;
LL n, ans=;
LL prime[maxn];
LL num[maxn]; LL ksm(LL a, LL b) {
if(b == ) return 1ll;
if(b == ) return a%mod;
LL tmp = ksm(a, b/)%mod;
if(b% == )
return ((tmp%mod)*(tmp%mod))%mod;
else
return ((((tmp%mod)*tmp)%mod)*(a%mod))%mod;
}
int main() {
scanf("%lld", &n);
not_prime[] = true;
for(LL i = ; i <= n; i++) {
if(!not_prime[i])
prime[++cnt] = i;
for(int j = ; j <= cnt; j++) {
if(prime[j]*i>n) break;
not_prime[prime[j]*i] = true;
if(i%prime[j] == ) break;
}
}
for(int i = ; i <= cnt; i++) {
LL aa = n;
while(aa != ) {
num[i] += aa/prime[i];
aa /= prime[i];
}
}
for(int i = ; i <= cnt; i++) {
if(num[i]% == )
ans = (ans*ksm(prime[i], num[i]))%mod;
else
ans = (ans*ksm(prime[i], num[i]-))%mod;
}
printf("%lld", ans);
return ;
}

考场代码

期望。。。不要爆零   实际。。。8分  qwq

思路:一看就是图论题,然后手动模拟了一下样例1,开始码代码。。发现后两个样例过不了我居然还以为样例错了,还去问老师。。傻的一批

正解:跑两边Floyd,第一次不考虑换马的情况求出最短路,第二次则要考虑换马 f[i][j] = min(f[i][k]+f[k][j]);

#include<algorithm>
#include<cstring>
#include<cstdio>
#include<queue>
#define M 10005
#define MAXN 0x3f3f3f
using namespace std;
queue<int> q;
int s, f;
int n, m, tot;
int e[M], v[M];
double dis[M], cap[M];
int to[M], net[M], head[M], vis[M]; void add(int u, int v, double w) {
to[++tot] = v; net[tot] = head[u]; head[u] = tot; cap[tot] = w;
}
void spfa(int x) {
for(int i = ; i <= n; i++)
dis[i] = 1.0*MAXN, vis[i] = ;
dis[x] = ; vis[x] = ; q.push(x);
while(!q.empty()) {
int y = q.front(); q.pop(); vis[y] = ;
for(int i = head[y]; i; i = net[i]) {
int t = to[i];
if(dis[t] > dis[y] + cap[i]) {
dis[t] = dis[y] + cap[i];
if(!vis[t]) vis[t] = , q.push(t);
}
}
}
// for(int i = 1; i <= n; i++) printf("%lf\n", dis[i]);
} int main() { scanf("%d%d", &n, &m);
for(int i = ; i <= n; i++)
scanf("%d%d", &e[i], &v[i]);
for(int i = ; i <= n; i++)
for(int j = ; j <= n; j++) {
int a;
scanf("%d", &a);
if(a == -) continue;
else if(e[i] < a) continue;
else {
double tmp = 1.0 * a / v[i];
add(i, j, tmp);
}
}
for(int i = ; i <= m; i++) {
scanf("%d%d", &s, &f);
spfa(s);
printf("%.6lf\n", dis[f]);
}
return ;
}

考场代码

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm> using namespace std; const int maxn=; int n,q,e[maxn],s[maxn]; double dis[maxn][maxn],dist[maxn][maxn]; int main()
{
int T=;
for (int t=;t<=T;t++)
{
scanf("%d%d",&n,&q);
for (int a=;a<=n;a++)
scanf("%d%d",&e[a],&s[a]);
for (int a=;a<=n;a++)
for (int b=;b<=n;b++)
{
scanf("%lf",&dis[a][b]);
if (dis[a][b]<) dis[a][b]=1e+;
if (a==b) dis[a][b]=;
}
for (int a=;a<=n;a++)
for (int b=;b<=n;b++)
for (int c=;c<=n;c++)
dis[b][c]=min(dis[b][c],dis[b][a]+dis[a][c]);
for (int a=;a<=n;a++)
for (int b=;b<=n;b++)
dist[a][b]=1e+;
for (int a=;a<=n;a++)
dist[a][a]=;
for (int a=;a<=n;a++)
for (int b=;b<=n;b++)
if (dis[a][b]<=e[a]) dist[a][b]=dis[a][b]/s[a];
for (int a=;a<=n;a++)
for (int b=;b<=n;b++)
for (int c=;c<=n;c++)
dist[b][c]=min(dist[b][c],dist[b][a]+dist[a][c]);
//printf("Case #%d:",t);
for (int a=;a<=q;a++)
{
int s,e;
scanf("%d%d",&s,&e);
printf("%.6lf\n",dist[s][e]);
}
} return ;
}

std

期望。。。不要爆零  实际。。骗分得到了10分   因为测试点数量比上一个少 qwq

思路:类似于滑动窗口,然后通过树状数组求解

树状数组似撒?能吃吗?qwq

骗分代码我就不展示了  捂脸

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm> using namespace std; #ifdef unix
#define LL "%lld"
#else
#define LL "%I64d"
#endif #define lb(x) ((x)&(-(x))) const int maxn=; int n,z[maxn],y[maxn],x[maxn]; long long k; bool cmp(int a,int b) {
return z[a]<z[b];
} void insert(int *z,int p,int d) {
for (; p<=n; p+=lb(p))
z[p]+=d;
} int query(int *z,int p) {
int ans=;
for (; p; p-=lb(p))
ans+=z[p];
return ans;
} int main() {
scanf("%d" LL,&n,&k);
for (int a=; a<=n; a++)
scanf("%d",&z[a]),y[a]=a;
sort(y+,y+n+,cmp);
x[y[]]=;
for (int a=; a<=n; a++)
if (z[y[a]]==z[y[a-]]) x[y[a]]=x[y[a-]];
else x[y[a]]=x[y[a-]]+;
for (int a=; a<=n; a++)
z[a]=x[a];
memset(x,,sizeof(x));
memset(y,,sizeof(y));
long long nowans=;
int p=n;
while (p>=) {
nowans+=query(y,z[p]-);
insert(y,z[p],);
p--;
}
p++;
long long ans=;
for (int a=; a<=n; a++) {
if (p==a) {
nowans-=a--query(x,z[p])+query(y,z[p]-);
insert(y,z[p],-);
p++;
}
nowans+=a--query(x,z[a])+query(y,z[a]-);
insert(x,z[a],);
while (nowans>k && p<=n) {
nowans-=a-query(x,z[p])+query(y,z[p]-);
insert(y,z[p],-);
p++;
}
if (nowans<=k) ans+=n-p+;
}
printf(LL "\n",ans); return ;
}

std

2018/8/15 qbxt 测试的更多相关文章

  1. 2018/8/21 qbxt测试

    2018/8/21 qbxt测试 期望得分:0? 实际得分:0 思路:manacher   会写模板但是不会用 qwq 听了某人的鬼话,直接输出0,然后就gg了 #include <cstdio ...

  2. 记2018/5/5 qbxt 测试

    记2018/5/5 qbxt 测试 竞赛时间: 2018 年 5 月 5 日 13:30-17:00 T1 一.maze(1s,512MB): 简单的迷宫问题:给定一个n*m的迷宫,.表示可以通过,# ...

  3. 记2018/4/29 qbxt 测试

    记 2018/4/29  qbxt 测试(提高基础班) 简单的 NOIP 模拟赛 竞赛时间: 2018 年 4 月 29 日 13:30-17:00 题目名称 乘法 求和 计数 输入文件名 mul.i ...

  4. Tencent Cloud Developers Conference(2018.12.15)

    时间:2018.12.15地点:北京朝阳悠唐皇冠假日酒店

  5. Lean Data Innovation Sharing Salon(2018.09.15)

    时间:2018.09.15地点:北京国华投资大厦

  6. JZOJ 5818. 【NOIP提高A组模拟2018.8.15】 做运动

    5818. [NOIP提高A组模拟2018.8.15] 做运动 (File IO): input:running.in output:running.out Time Limits: 2000 ms  ...

  7. WPF 使用鼠标拖动一个控件的实现[2018.7.15]

    原文:WPF 使用鼠标拖动一个控件的实现[2018.7.15] Q:已经把一个Shape和一个TextBlock组合起来放到了一个Grid中,现在想要实现用鼠标拖动这个Grid到任意位置的功能,如何做 ...

  8. WPF 在绘图控件(Shape)中添加文字 [2018.7.15]

    原文:WPF 在绘图控件(Shape)中添加文字 [2018.7.15] Q:使用Shape的子类Ellipse画一个圆,如何在圆中添加文字? A:Shape类中不包含Text属性.可使用Shape类 ...

  9. 2018中国科大自主测试-B卷部分试题

    数学部分 z = e^{\frac{2i\pi}{3}}, 求z^{2018}. \sin(2x) = \frac 35, 求\frac{\tan(x+15^{\circ})}{\tan(x-15^{ ...

随机推荐

  1. [Java][log4j]支持同一时候按日期和文件大小切割日志

    依据DailyRollingFileAppender和RollingFileAppender改编,支持按日期和文件大小切割日志.  源文件: package com.bao.logging; impo ...

  2. org.mybatis.spring.mapper.MapperScannerConfigurer$Scanner$1

    不能加载或找不到 org.mybatis.spring.mapper.MapperScannerConfigurer$Scanner$1 经查证,是mybatis-spring-xxx.jar 这个版 ...

  3. Ubuntu源配置

    一.图形界面配置 新手推荐使用图形界面配置: 系统工具 -> 软件和更新-> Ubuntu软件-> 下载自:-> 其他站点  点击 选择最佳服务器(将通过连接测试确定最佳镜像) ...

  4. 新手教程:电信+广电(或其他运营商)双WAN设置

    由于国内不同运营商之间互联互通存在问题,假如用联通的线路去访问电信的站点那么会比较卡,反之亦然:所以如果两个WAN的线路不是同一个运营商,一般都是建议用户双WAN模式选为“智能路由”.经过本人测试发现 ...

  5. AOP 动态添加函数

    Function.prototype.before = function(beforefn) { // 保存原函数的引用 var self = this; // 返回包含了原函数和新函数的代理函数 r ...

  6. WebAssembly学习(六):AssemblyScript - 限制与类型

    一.限制 将无类型的JavaScript编译为WebAssembly没有意义,因为它最终会导致运行其中较慢的一个JavaScript. 相反,AssemblyScript专注于WebAssembly擅 ...

  7. BZOJ2636: crisis(可持久化线段树)

    传送门: 解题思路: 题目描述是一大坑点,cancel后面是直接加ask或者redo的. 那么就可以愉快地可持久化了. 注意需要支持区间修改,那么就只需要在再次更新这个点的时候将标记储存在新的儿子中. ...

  8. BZOJ2668: [cqoi2012]交换棋子(费用流)

    Description 有一个n行m列的黑白棋盘,你每次可以交换两个相邻格子(相邻是指有公共边或公共顶点)中的棋子,最终达到目标状态.要求第i行第j列的格子只能参与mi,j次交换. Input 第一行 ...

  9. 洛谷 P1239 计数器

    P1239 计数器 题目描述 一本书的页数为N,页码从1开始编起,请你求出全部页码中,用了多少个0,1,2,…,9.其中—个页码不含多余的0,如N=1234时第5页不是0005,只是5. 输入输出格式 ...

  10. ESP8266学习笔记4:ESP8266的SmartConfig

    今天花了将近一天的时间来研究ESP8266的SmartConfig功能,这个应该算是wifi云产品的标配.这篇文章先把SmartConfig操作一遍,我还写了还有一篇文章梳理了物理层的详细协议,点击这 ...