CodeForces 70
A题
#include<bits/stdc++.h>
using namespace std;
int n,b,sum;
int main(){
scanf("%d",&n);
if (n==0){
printf("1\n");
return 0;
}
int b=3,sum=1;
for (int i=1;i<n;++i)
sum=(sum*b)%1000003;
printf("%d",sum);
return 0;
}
B题
难得我能在一群大佬中抢个一血的题
#include<bits/stdc++.h>
using namespace std;
string s;
vector<int>a;
int n,m,ans;
int main(){
scanf("%d",&n),m=1;
getline(cin,s);getline(cin,s);
for(register int i=0;i<s.size();++i)
if(s[i]!='?'&&s[i]!='.'&&s[i]!='!')
++m;
else if(m>n){
printf("Impossible\n");
return 0;
}
else a.push_back(m),m=0;
for(register int i=0;i<a.size();++i)
if(m+a[i]+1<=n&&m>0)
m+=a[i]+1;
else
++ans,m=a[i];
printf("%d\n",ans);
return 0;
}
C题 (siyuan)
#include <bits/stdc++.h>
#define MAXN 100010
using namespace std;
int maxx,maxy,w,b,cd,x;
pair<int,int> f[MAXN],f1[MAXN],ans;
map<pair<int,int>,int> a,b1;
inline pair<int,int> sc(int maxx,int maxy,int w){
int x=MAXN,y=MAXN;
for(int i=1,j=0,s=0;i<=maxx;++i){
a[f[i]]++,s+=b1[f1[i]];
while(s<w&&j<maxy)
s+=a[f1[++j]],b1[f[j]]++;
while(j>0&&s-a[f1[j]]>=w)
s-=a[f1[j]],b1[f[j]]--,j--;
if(s>=w&&(1LL*i*j<1LL*x*y))
x=i,y=j;
}
return pair<int,int>(x,y);
}
int main(){
scanf("%d%d%d",&maxx,&maxy,&w);
for(int i=1;i<=max(maxx,maxy);i++){
b=0,x=i;
while (x) b=b*10+x%10,x/=10;
cd=__gcd(i,b);
f[i]=pair<int,int>(i/cd,b/cd);
f1[i]=pair<int,int>(b/cd,i/cd);
}
ans=sc(maxx,maxy,w);
if(ans.first==100010)
printf("-1\n");
else
printf("%d %d\n",ans.first,ans.second);
return 0;
}
D题
517昨天刚刚讲过的题,可我还是不会,我太菜了
#include <bits/stdc++.h>
using namespace std;
const double MIN=1e-8;
const double pi=3.141592653589793238462643383;
int q,i,c,x[10],y[10],xx,yy,x1,x2,yy1,y2;
struct Node{
double a,b,c,d;
Node(double x=0,double y=0){
a=x,b=y,c=sqrt(x*x+y*y);
if (abs(x)<MIN){
if (y>MIN)
d=pi*0.5;
else d=pi*(-0.5);
}
else{
if (x>MIN)
d=atan(y/x);
else{
if (y>MIN)
d=pi+atan(y/x);
else
d=-pi+atan(y/x);
}
}
}
}p;
Node operator-(Node a,Node b){
return Node(a.a-b.a,a.b-b.b);
}
double operator*(Node a,Node b){
return a.a*b.b-a.b*b.a;
}
bool operator<(Node a,Node b){
if (a.d==b.d)
return a.c<b.c;
else
return a.d<b.d;
}
bool operator>(Node a,Node b){
if (a.d==b.d)
return a.c>b.c;
else
return a.d>b.d;
}
set<Node>s;
set<Node>::iterator s1;
set<Node>::iterator nex(set<Node>::iterator x){
x++;
if (x==s.end())
return s.begin();
else
return x;
}
set<Node>::iterator pre(set<Node>::iterator x){
if (x==s.begin())
x=s.end();
x--;
return x;
}
int main(){
scanf("%d",&q);q-=3;
for (int i=0;i<3;++i){
scanf("%d%d%d",&c,&x[i],&y[i]);
x1=x1+x[i],yy1=yy1+y[i];
}
x1/=3.0,yy1/=3.0;
for (int i=0;i<3;++i)
s.insert(Node(x[i]-x1,y[i]-yy1));
while (q--){
scanf("%d%d%d",&c,&x2,&y2);
xx=x2-x1,yy=y2-yy1;
p=Node(xx,yy);
s1=s.lower_bound(p);
if(s1==s.end())
s1=s.begin();
if (c==1){
if ((p-*pre(s1))*(*s1-p)>MIN){
s.insert(p);
s1=nex(s.find(p));
while (s.size()>3&&(*s1-p)*(*nex(s1)-*s1)<MIN){
s.erase(s1);
s1=nex(s.find(p));
}
s1=pre(s.find(p));
while (s.size()>3&&(*s1-*pre(s1))*(p-*s1)<MIN){
s.erase(s1);
s1=pre(s.find(p));
}
}
}
else {
if ((p-*pre(s1))*(*s1-p)<MIN)
printf("YES\n");
else
printf("NO\n");
}
}
return 0;
}
E题
这题就不放自己的代码了,siyuan小姐姐真的tql%%%
CodeForces 70的更多相关文章
- codeforces 70 D. Professor's task 动态凸包
地址:http://codeforces.com/problemset/problem/70/D 题目: D. Professor's task time limit per test 1 secon ...
- Codeforces Beta Round #70 (Div. 2)
Codeforces Beta Round #70 (Div. 2) http://codeforces.com/contest/78 A #include<bits/stdc++.h> ...
- 水题 Codeforces Beta Round #70 (Div. 2) A. Haiku
题目传送门 /* 水题:三个字符串判断每个是否有相应的元音字母,YES/NO 下午网速巨慢:( */ #include <cstdio> #include <cstring> ...
- 【55.70%】【codeforces 557A】Ilya and Diplomas
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
- 【22.70%】【codeforces 591C】 Median Smoothing
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- Codeforces 331A2 - Oh Sweet Beaverette (70 points)
贪心搞就行,用map记录每个数出现的下标,每次都取首尾两个.将中间权值为负的删掉后取sum值最大的就行. #include<iostream> #include<algorithm& ...
- 【29.70%】【codeforces 723D】Lakes in Berland
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- Educational Codeforces Round 70 (Rated for Div. 2)
这次真的好难...... 我这个绿名蒟蒻真的要崩溃了555... 我第二题就不会写...... 暴力搜索MLE得飞起. 好像用到最短路?然而我并没有学过,看来这个知识点又要学. 后面的题目赛中都没看, ...
- Educational Codeforces Round 70 题解
噩梦场. 题目出奇的难,好像一群外国老哥看 A 看着看着就哭了-- A 找到 \(b\) 最低的 \(1\),这个 \(1\) 肯定要跟 A 中的一个 \(1\) 搭配,而且是能搭配的 \(1\) 中 ...
随机推荐
- MongoDB:配置与安装
一.配置环境 1.1进行安装下载msi文件 需要注意的一点是,在安装过程中的图示界面不要勾选左下角“安装MongoDB可视化工具”.这是一个客户端管理工具,在后面会具体描述其功能.由于安装时间非常长, ...
- Numpy库的下载与安装总结
今天在做Plotly的散点图时,需要Numpy 这个库的使用 没有安装Numpy这个库的时候,报错一般是下图这样:ModuleNotFoundError: No module named 'numpy ...
- Chrome浏览器,处理input自动填充时带黄色背景色
/*Chrome浏览器打开网页,input自动赋值时,会带上屎黄色的背景色,下面是通过延长增加自动填充背景色的方式, 让用户感受不到样式的变化*/ input:-webkit-autofill, in ...
- Ext.grid.panel 改变某一行的字体颜色
grid.getStore().addListener('load', handleGridLoadEvent); function handleGridLoadEvent(store, record ...
- [20190415]11g下那些latch是共享的.txt
[20190415]11g下那些latch是共享的.txt http://andreynikolaev.wordpress.com/2010/11/23/shared-latches-by-oracl ...
- Redis事务涉及的watch、multi等命令
Redis Watch 命令 作用: 用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断. 用法: redis 127.0.0.1:6379 ...
- access denied for user 'root'@'localhost'(using password:YES) FOR WINDOWS
以windows为例: mysql5.5 1. 关闭正在运行的MySQL服务. 2. 打开DOS窗口,转到mysql\bin目录. 3. 输入mysqld --skip-grant-tables 回车 ...
- python模块shutil
shutil.copyfileobj(fsrc, fdst,[ length]) 拷贝文件句柄,将类文件对象fsrc的内容复制到类文件对象fdst.如果给定整数长度,则为缓冲区大小.如果长度是负值意味 ...
- chrome打开收藏夹的网站在新的标签页
chrome浏览器在新的标签页打开收藏夹的网址,现在设置不了,而且右键,在新标签页中打开有点烦..下面说说直接打开的方式. 方法1: 鼠标滚轮,直接点击收藏夹的网址,即可 方法2: ctrl + 鼠标 ...
- 把exe注册为windows服务
1.需要工具 Instsrv.exe(可以给系统安装和删除服务) Srvany.exe(可以让程序以服务的方式运行) 2.运行cmd,输入注册服务命令 "instsrv.exe完整路径&qu ...