这次精神状态不怎么好,第一题的描述看得我就蛋疼。。。看完就速度写了~~~最终fst了%>_<%,第二题写复杂了,一直WA pretest 3,然后就紧张,导致精神更不好了,一直纠结在第二题,时间就这样过了,再一次拿了0蛋,妈蛋,真是蒟蒻啊%>_<%

A.看懂题之后就是A+B problem

代码:

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <string>
#include <map>
using namespace std;
int main()
{
int n,c;
cin>>n>>c;
int a,ans=0;
cin>>a;
for(int i=2;i<=n;i++)
{
int b;
cin>>b;
ans=max(ans,a-b-c);
a=b;
}
cout<<ans<<endl;
return 0;
}

B.给定字符串s = s1s2... s|s| ,问包含单词"bear"的子串有多少个?

假设当前字符串的长度为n,找到第一个"bear"所在的开始位置pos,那么符合要求的子串就有pos*(n-pos-2)个,之后把子串s1~spos删除

重复以上步骤,直至没有单词"bear"

代码:

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <string>
#include <map>
using namespace std;
#define MAXN 5555
string s;
int main()
{
cin>>s;
int ans=0,pos;
while((pos=s.find("bear"))!=-1)
{
ans+=(pos+1)*(s.size()-pos-3);
s.erase(s.begin(),s.begin()+pos+1);
}
cout<<ans<<endl;
return 0;
}

C.给定一个序列x[1],x[2],x[3],……x[n],然后接下来有m个查询,对于每个查询给出两个数l和r,要求你返回区间[l,r]内的每一个质数能够整除的序列元素个数的累加和

没有修改,只有查询,果断的离线~~~先用素数的线性筛法求出每个x[i]的最小质数因子,接下来对每个x[i]进行质因数分解,并对相应的因子进行统计,搞完之后再计算出前缀和出来(用sum数组表示)

,那么对于查询[l,r],结果就是sum[r]-sum[l-1]

代码:

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <string>
#include <map>
using namespace std;
#define MAXN 10000005
typedef long long LL;
int a[MAXN];
LL sum[MAXN];
int prime[MAXN],cnt=0;
int check[MAXN];
void get_prime()
{
memset(check,0,sizeof(check));
for(int i=2; i<MAXN; i++)
{
if(!check[i])
{
prime[cnt++]=i;
check[i]=i;
}
for(int j=0; j<cnt&&i*prime[j]<MAXN; j++)
{
check[i*prime[j]]=prime[j];
if(i%prime[j]==0) break;
}
}
}
void fac(int n)
{
for(int i=0; i<n; i++)
{
int d=a[i];
int pre=-1;
while(d!=1)
{
if(pre!=check[d])
sum[check[d]]++;
pre=check[d];
d/=check[d];
}
}
}
int main()
{
int n,m;
get_prime();
scanf("%d",&n);
for(int i=0; i<n; i++) scanf("%d",&a[i]);
fac(n);
for(int i=1; i<MAXN; i++) sum[i]+=sum[i-1];
scanf("%d",&m);
while(m--)
{
int l,r;
scanf("%d%d",&l,&r);
r=min(r,10000000);
if(l>r) printf("0\n");
else
printf("%I64d\n",sum[r]-sum[l-1]);
}
return 0;
}

D.略 计算几何全还给高中数学老师了。。。有时间得在好好学学

E.题目描述就不说了,就是给定几个变量的变化关系,问你在t次变化之后的值

根据题目意思可以求出各个变量的递推式来,由于t很大(t<1018),所以线性模拟肯定超时,于是就要用到矩阵快速幂来加速递推(这学期刚好学了线代~~~),构造出矩阵之后进行快速幂运算就OK

代码:

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <vector>
using namespace std;
const int maxn=6;
typedef long long LL;
typedef long long Matrix[maxn][maxn];
LL M[maxn][maxn]=
{
{2,1,1,0,1,0},
{1,2,0,1,1,0},
{1,1,1,0,1,0},
{1,1,0,1,1,0},
{0,0,0,0,1,1},
{0,0,0,0,0,1},
};
LL n;
void matrix_mul(Matrix A, Matrix B, Matrix res)
{
Matrix C;
memset(C, 0, sizeof(C));
for(int i = 0; i < 6; i++)
for(int j = 0; j < 6; j++)
for(int k = 0; k < 6; k++) C[i][j] = (C[i][j] + A[i][k] * B[k][j])%n;
memcpy(res, C, sizeof(C));
}
void matrix_pow(Matrix A,Matrix res,LL n)
{
Matrix a, r;
memcpy(a, A, sizeof(a));
memset(r, 0, sizeof(r));
for(int i = 0; i < 6; i++) r[i][i] = 1;
while(n)
{
if(n&1) matrix_mul(r, a, r);
n >>= 1;
matrix_mul(a, a, a);
}
memcpy(res, r, sizeof(r));
}
int main()
{
LL sx,sy,dx,dy,t;
Matrix A,B;
cin>>n>>sx>>sy>>dx>>dy>>t;
matrix_pow(M,A,t);
memset(B,0,sizeof(B));
B[0][0]=sx,B[1][0]=sy,B[2][0]=dx;
B[3][0]=dy,B[4][0]=0,B[5][0]=1;
matrix_mul(A,B,B);
LL x,y;
x=B[0][0],y=B[1][0];
if(x<=0) x+=n;
if(y<=0) y+=n;
cout<<x<<" "<<y<<endl;
return 0;
}

Codeforces Round #226 (Div. 2 )的更多相关文章

  1. Codeforces Round #226 (Div. 2) B

    B. Bear and Strings time limit per test 1 second memory limit per test 256 megabytes input standard ...

  2. Codeforces Round #226 (Div. 2)C. Bear and Prime Numbers

    /* 可以在筛选质数的同时,算出每组数据中能被各个质数整除的个数, 然后算出[0,s]的个数 [l,r] 的个数即为[0,r]的个数减去[0,l]个数. */ #include <stdio.h ...

  3. Codeforces Round #226 (Div. 2)A. Bear and Raspberry

    /* 贪心的找到相邻两项差的最大值,再减去c,结果若是负数答案为0. */ 1 #include <stdio.h> #define maxn 105 int num[maxn]; int ...

  4. Codeforces Round #226 (Div. 2)B. Bear and Strings

    /* 题意就是要找到包含“bear”的子串,计算出个数,需要注意的地方就是不要计算重复. */ 1 #include <stdio.h> #include <string.h> ...

  5. 【计算几何】【状压dp】Codeforces Round #226 (Div. 2) D. Bear and Floodlight

    读懂题意发现是傻逼状压. 只要会向量旋转,以及直线求交点坐标就行了.(验证了我这俩板子都没毛病) 细节蛮多. #include<cstdio> #include<algorithm& ...

  6. Codeforces Round #226 (Div. 2) C题

    数论好题 题目要求:求给定序列的素因子如果在给定区间内该数字个数加1; 思路:打表时求出包含给素数因子的数的个数,详见代码 1 #include<cstring> +;      scan ...

  7. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  8. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  9. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

随机推荐

  1. 改善用户体验之wordpress添加图片弹出层效果 (插件 FancyBox)

    下面说说在改善用户体验之wordpress添加图片弹出层效果.效果图如下:   像这篇文章如何在百度搜索结果中显示网站站点logo? 文章内有添加图片,没加插件之前用户点击图片时,是直接_black打 ...

  2. linux telnet命令参数及用法详解--telnet连接远程终端命令

    功能说明:远端登入. 语 法:telnet [-8acdEfFKLrx][-b<主机alias.html' target='_blank'>别名>][-e<脱离字符>][ ...

  3. CF 369 B. Valera and Contest

    http://codeforces.com/contest/369/problem/B 题意 :n, k, l, r, sall, sk,n代表的是n个人,这n个人的总分是sall,每个人的得分大于 ...

  4. hdu 4672 Present Day, Present Time 博弈论

    看了解题报告才知道怎么做!! 题意:有 N 堆石子和 M 个石子回收站,每回合操作的人可以选择一堆石子,从中拿出一些 放到石子回收站里(可以放进多个回收站,每个回收站可以使用无数次),但每个石子回收站 ...

  5. 孟岩的c++ 的学习方法,这何尝有不是做人做事的方法呢?

    “(孟岩)我主张,在具备基础之后,学习任何新东西,都要抓住主线,突出重点.对 于关键理论的学习,要集中精力,速战速决.而旁枝末节和非本质性的知识内容,完全可 以留给实践去零敲碎打. “原因是这样的,任 ...

  6. Get请求携带数据量的各种限制及解决办法、Post请求说明

    1.   Get请求携带数据量的各种限制及解决办法 Http Get方法提交的数据大小长度并没有限制,HTTP协议规范没有对URL长度进行限制.这个限制是特定的浏览器及服务器对它的限制. 到新公司处理 ...

  7. DX 绘制位图

    简单地学习了四个API: HRESULT CreateOffscreenPlainSurface( [in] UINT Width, // 宽度 [in] UINT Height, // 高度 [in ...

  8. 使用Mysql命令一次性备份多个数据库(所有数据库)

    通过CMD命令窗口 1.找到Mysql的安装目录\mysql\BIN目录 2. 输入mysqldump --all-databases -h127.0.0.1 -uroot -p123456 > ...

  9. 在Tomcat上配置CAS 自己的体验

    演示环境 本文演示过程在同一个机器上的(也可以在三台实体机器或者三个的虚拟机上),环境如下: windows732位 JDK 1.6.0_18 Tomcat 6.0.29 CAS-server-3.4 ...

  10. NFC(5)编写NFC程序的基本步骤

    1,设置权限 <uses-permission android:name="android.permission.NFC" /> 2,限制Android版本 <u ...