很长时间没更新有意义的题目了呢,这是一套题撒,于是乎我便开心的边刷题边发题解了撒.

第一题: interval

比较好玩的一题撒, 分分钟过了, 就是模拟贪吃蛇但是没有食物(嗯,只要你判断冲突).

整个数组拿来移当然是不行的撒, 只要在末尾移去一个方格再向头部正对出放一个方格就行了撒.

编程复杂度挺低的, 可以直接修改一下做贪吃蛇游戏的后台.

(最坑的地方就是坐标系.无图无**)

其实也不算很坑啦.

#include <cstdio>
#include <cstring>
struct point{
int x,y;
};
point gpos(char ch,point c){
switch(ch){
case 'E':
++c.x;
break;
case 'W':
--c.x;
break;
case 'S':
--c.y;
break;
case 'N':
++c.y;
break;
}
return c;
}
struct queue{
point q[2000],t;
bool map[100][100];
int s,e,i;
int move(char c){
map[q[s].x][q[s].y]=false;
++s;
t=gpos(c,q[e-1]);
if(t.x>50||t.x<0) return 1;
if(t.y>50||t.y<0) return 1;
if(map[t.x][t.y]) return 2;
map[t.x][t.y]=true;
q[e]=t;
++e;
return 0;
}
void reset(){
memset(map,0,sizeof map);
memset(q,0,sizeof q);
s=e=0;
for(i=11;i<=30;++i){
q[e].y=25;
q[e].x=i;
map[i][25]=true;
++e;
}
}
} q;
int i,j,n;
char c,str[1000];
bool f;
int main(){
freopen("interval.in","r",stdin);
freopen("interval.out","w",stdout);
while(scanf("%d\n",&n),n){
q.reset();
f=false;
scanf("%s",str);
for(i=0;i<n;++i){
c=str[i];
j=q.move(c);
if(j){
if(j==1){
printf("The worm ran off the board on move %d.\n", i+1);
}else{
printf("The worm ran into itself on move %d.\n", i+1);
}
f=true;
break;
}
}
if(!f) printf("The worm successfully made all %d moves.\n", n);
}
return 0;
}

第二题 直角三角形

平面上给定 n 个两两不同的整数点,统计以给定的点为顶点,其直角边平行于坐标轴的直角三角形的个数.

嗯横纵轴离散化.(嗯hash似乎比较好,统计x,y的实在不想写啊摔)

为什么离散化呢因为数据范围不小.

30%的数据满足 n≤100;
50%的数据满足 n≤1000;
100%的数据满足 0<n≤100,000,所有坐标不超过 32 位整数范围。

就是这样辣.

#include <cstdio>
struct node{
int d,n;
long long s;
} p[200000];
int he[2][103979],pl,temp,temp2;
inline int find(int h,bool n){
temp=h;
temp2=h=h%103979;
h=he[n][h];
while(h && p[h].d!=temp) h=p[h].n;
if(h) return h;
++pl;
p[pl].n=he[n][temp2];
p[pl].d=temp;
p[pl].s=0;
he[n][temp2]=pl;
return pl;
}
long long sum;
int i,n,a,b;
int xs[200000],ys[200000];
int main(int argc, char const *argv[]){
freopen("right.in","r",stdin);
freopen("right.out","w",stdout);
scanf("%d",&n);
for(i=0;i<n;++i){
scanf("%d %d",&a,&b);
xs[i]=a;
ys[i]=b;
a=find(a,0),b=find(b,1);
++p[a].s,++p[b].s;
}
for(i=0;i<n;++i){
a=find(xs[i],0),b=find(ys[i],1);
sum+=(p[a].s-1)*(p[b].s-1);
}
printf("%lld\n", sum);
return 0;
}

(简直短到奇葩)

二模 06day2的更多相关文章

  1. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  2. 二模 (8) day2

    第一题: 题目描述: 有 n 个炸弹,有些炸弹牵了一根单向引线(也就是说引线只有在这一端能被炸弹点燃),只要引爆了这个炸弹,用引线连接的下一个炸弹也会爆炸.每个炸弹还有个得分,当这个炸弹被引爆后就能得 ...

  3. RSA简介(二)——模幂算法

    RSA最终加密.解密都要用到模乘的幂运算,简称模幂运算. 回忆一下RSA,从明文A到B B=Ae1%N 对B解密,就是 A=Be2%N 其中,一般来说,加密公钥中的e1一般会比较小,取65537居多, ...

  4. 二模14day1解题报告

    注:Index数☞由4,7组成的十进制数. T1.全排列(permutation) 求n个数的第k个排列中,有多少个Index位置上是Index数. 由于k的范围比较小,n的范围比较大(都是109), ...

  5. 二模12day2解题报告

    T1.笨笨玩糖果(sugar) 有n颗糖,两个人轮流取质数颗糖,先取不了的(0或1)为输,求先手能否必胜,能,输出最少几步肯定能赢:不能,输出-1. 一开始天真的写了一个dp,f[i]表示i颗糖最少取 ...

  6. 二模01day1解题报告

    T1.音量调节(changingsounds) 有n个物品的背包(有点不一样,每个物品必须取),给出初始价值,物品价值可正可负(就是两种选择嘛),求可能的最大价值,不可能(<0或>maxs ...

  7. 二模 (12) day1

    第一题: 题目大意: 求由N个1,M个0组成的排列的个数,要求在排列的任意一个前缀中,1的个数不少于0的个数.N,M<=5000. 解题过程: 1.看到N,M的范围就明确肯定不会是dp,因为起码 ...

  8. 二模 (9) day2

    第一题: 题目大意:求满足条件P的N位二进制数的个数.P:该二进制数有至少3个0或者3个1挨在一起.. N<=20000 解题过程: 1.一开始直接写了个dfs把表打了出来,不过没发现什么规律, ...

  9. 二模 (3) day1

    第一题: 题目描述: 一个数列定义如下:f(1) = 1,f(2) = 1,f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7.给定 A,B 和 n 的值,要求计算 ...

随机推荐

  1. [设计模式] javascript 之 代理模式

    代理模式说明 说明:顾名思义就是用一个类来代替另一个类来执行方法功能,这个模式跟装饰模式有点相似,不一样的是,代理模式是代替客户初始化被代理对象类,而装饰模式采用接口或初装饰者参数引用的方式来执行的. ...

  2. 每天一个linux命令(38):vmstat命令

    vmstat 是Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存.进程.CPU活动进行监控.他是对系统的整体 情况进行统计,不足之处是无法对某个进程进 ...

  3. hdu4763 KMP

    稀里糊涂1A开心.我做了2次kmp,先第一次利用next[],由于next[]前面一小段一直是一样的,所以可以根据这个来找.然后就找到了开头和结尾,还缺中间的部分. 中间的部分就是通过开头部分去模式匹 ...

  4. Spring-如何实现事物管理的

    事务的实现方式 实现方式共有两种:编码方式:声明式事务管理方式.基于AOP技术实现的声明式事务管理,实质就是:在方法执行前后进行拦截,然后在目标方法开始之前创建并加入事务,执行完目标方法后根据执行情况 ...

  5. Java编程思想学习(七) 抽象类和接口

    1.抽象类和抽象方法 抽象方法:不完整的,仅有声明而没有方法体. abstract void f(); 抽象类:包含抽象方法的类.(若一个类包含一个或多个抽象方法,则该类必须限定为抽象的.) 1.用抽 ...

  6. Windows Server 2008 显示桌面图标

    相信有朋友们有安装使用过windows 2008 server服务器,刚安装好的时候,桌面上只有一个回收站的图标,它没有像windows 7或windows 8一样可以直接通过右击鼠标的菜单来设置,要 ...

  7. C#二进制文件的读写

    sing System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using ...

  8. UDP 内网穿透 心跳

    参考:http://blog.csdn.net/jacman/article/details/ 1: 启动一个Server. 2: 启动两个Client. 然后从Server端的Console里边可以 ...

  9. char*和char []

    1.char *s1 = "ssss"; 2.char s2[] = "bbbb"; 对于第一种,我是无法理解,无法想象字符串赋值给一个char类型的指针,查了 ...

  10. C++ map 映照容器

    map映照容器的元素数据是一个键值和一个映照数据组成的,键值与映照数据之间具有一一映照的关系. map映照容器的数据结构是采用红黑树来实现的,插入键值的元素不允许重复,比较函数只对元素的键值进行比较, ...