/*
big模拟
细节不少
remove表示这个玩意儿在这一秒有没有移动
注意在一秒内所有小葱一起移动,所以如果一个一个处理
别忘了“错位”这种情况
*/
#include<iostream>
#include<cstdio>
#include<cstring> #define N 1001 using namespace std;
int n,m,T,k,ans;
int belong[N][N],cnt[N][N];
struct C{
int x,y,flag1,turn,f,remove;
}p[N]; inline int read()
{
int x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} bool can(int x)
{
if(p[x].remove==) return true;
if(p[x].x== && p[x].turn==) return true;
if(p[x].x==n && p[x].turn==) return true;
if(p[x].y== && p[x].turn==) return true;
if(p[x].y==m && p[x].turn==) return true;
return false;
} void judge(int i,int o)
{
if(cnt[p[i].x][p[i].y])
{
if(can(belong[p[i].x][p[i].y]))
{
if(p[belong[p[i].x][p[i].y]].f>p[i].f) p [i].flag1=;
else p[belong[p[i].x][p[i].y]].flag1=,belong [p[i].x][p[i].y]=i;
}
else
{
belong[p[i].x][p[i].y]=i;
cnt[p[i].x][p[i].y]++;
}
}
else
{
belong[p[i].x][p[i].y]=i;
cnt[p[i].x][p[i].y]++;
}
} int main()
{
freopen("problem.in","r",stdin);
freopen("problem.out","w",stdout);
n=read();m=read();k=read();
for(int i=;i<=k;i++) p[i].x=read(),p[i].y=read(),
p[i].turn=read(),p[i].f=read();
T=read();
for(int i=;i<=k;i++)
belong[p[i].x][p[i].y]=i,cnt[p[i].x][p[i].y]++; while(T--)
{
for(int i=;i<=k;i++) p[i].remove=;
for(int i=;i<=k;i++)
{
if(p[i].flag1) continue;
if(p[i].turn==)
{
if(p[i].x>)
{
cnt[p[i].x][p[i].y]--;
if(belong[p[i].x][p[i].y]==i)
belong[p[i].x][p[i].y]=;
p[i].x--;
judge(i,);p[i].remove=;
}
else {p[i].turn=;p [i].remove=;continue;}
}
if(p[i].turn==)
{
if(p[i].x<n)
{
cnt[p[i].x][p[i].y]--;
if(belong[p[i].x][p[i].y]==i)
belong[p[i].x][p[i].y]=;
p[i].x++;
judge(i,);p[i].remove=;
}
else {p[i].turn=;p[i].remove=;continue;}
}
if(p[i].turn==)
{
if(p[i].y>)
{
cnt[p[i].x][p[i].y]--;
if(belong[p[i].x][p[i].y]==i)
belong[p[i].x][p[i].y]=;
p[i].y--;
judge(i,);p[i].remove=;
}
else {p[i].turn=;p [i].remove=;continue;}
}
if(p[i].turn==)
{
if(p[i].y<m)
{
cnt[p[i].x][p[i].y]--;
if(belong[p[i].x][p[i].y]==i)
belong[p[i].x][p[i].y]=;
p[i].y++;
judge(i,);p[i].remove=;
}
else {p[i].turn=;p [i].remove=;continue;}
}
}
}
for(int i=;i<=k;i++) printf("%d %d\n",p[i].x,p[i].y);
fclose(stdin);fclose(stdout);
return ;
}
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm> using namespace std; const int maxn=;
const int maxk=; int n,m,k,x[maxk],y[maxk],d[maxk],f[maxk],z[maxk],t; bool alive[maxk]; int dx[],dy[]; void move(int p)
{
x[p] += dx[d[p]];
y[p] += dy[d[p]];
if (x[p]< || x[p]>n || y[p]< || y[p]>m)
{
x[p] -= dx[d[p]];
y[p] -= dy[d[p]];
d[p] ^= ;
}
} bool cmp(int a,int b)
{
if (x[a]!=x[b]) return x[a]<x[b];
else return y[a]<y[b];
} int main()
{
dx[]=-;dx[]=;dy[]=-;dy[]=;
scanf("%d%d%d",&n,&m,&k);
for (int a=;a<=k;a++)
scanf("%d%d%d%d",&x[a],&y[a],&d[a],&f[a]);
for (int a=;a<=k;a++)
{
alive[a]=true;
z[a]=a;
}
scanf("%d",&t); for (;t--;)
{
for (int a=;a<=k;a++)
if (alive[a]) move(a);
sort(z+,z+k+,cmp); for (int a=;a<=k;)
{
int b=a,p=-;
while (x[z[b]]==x[z[a]] && y[z[b]]==y[z[a]] && b<=k)
{
if (alive[z[b]] && (p==- || f[z[b]]>f[z[p]])) p=b;
b++;
}
for (int c=a;c<b;c++)
if (p!=- && c!=p) alive[z[c]]=false;
a=b;
}
}
for (int a=;a<=k;a++)
printf("%d %d\n",x[a],y[a]); return ;
}

知道自己代码丑 std0.0

/*
题意不好懂,自行体会。
20暴力 dfs
加剪枝可能会多跑过两个点
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<map> #define mod 12345 #define N 9001
using namespace std;
int n,m,flag;
long long ans;
char c[N],cur[N];
int b[N],vis[N];
map<char,int>cnt; inline int read()
{
int x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} void dfs(int now)
{
if(now==n+)
{
for(int i=;i<=m;i++) cnt[c[i]]=;
flag=;
for(int i=;i<=n;i++) cnt[cur[i]]++;
for(int i=;i<=m;i++)
if(cnt[c[i]]%b[i] && cnt[c[i]]) flag=;
if(!flag) ans++,ans%=mod;
return;
}
for(int i=;i<=m;i++)
{
if(!vis[now]) vis[now]=,cur[now]=c[i];
dfs(now+);vis[now]=;
}
} int main()
{
freopen("too.in","r",stdin);
freopen("too.out","w",stdout);
n=read();m=read();
for(int i=;i<=m;i++) cin>>c[i]>>b[i];
dfs();ans%=mod;
printf("%lld\n",ans);
return ;
}

/*
30暴力
bitset预处理任意两点间边数 e[i][j]
然后dp dp[i]表示1->i路径数
dp[i+1]=Σdp[j]*e[j][i+1] (j<=i)
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<bitset> #define N 1007
#define mod 991127
#define ll long long using namespace std;
bitset<>a;
bitset<>b;
bitset<>c;
int n,m,num[N];
ll e[N][N],dp[N]; inline int read()
{
int x=,f=;char c=getchar();
while(c>''||c<''){if(c=='-')f=-;c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x*f;
} int main()
{
freopen("easy.in","r",stdin);
freopen("easy.out","w",stdout);
n=read();
for(int i=;i<=n;i++) num[i]=read();
for(int i=;i<=n;i++) for(int j=i+;j<=n;j++)
{
a=num[i];b=num[j];c=a&b;
e[i][j]=c.count();e[i][j]%=mod;
}
dp[]=;ll tmp=;
for(int i=;i<n;i++)
{
tmp=;
for(int j=;j<=i;j++)
{
tmp+=(dp[j]*e[j][i+])%mod;
tmp%=mod;
}
dp[i+]+=tmp;dp[i+]%=mod;
}
dp[n]%=mod;
printf("%lld\n",dp[n]);
return ;
}
/*
注意题目要求只能编号小的往大的连边
f[i]表示第i位是1的数的贡献,编号由小到大类似前缀和累计
先枚举每个点权
如果当前点第i位是1的话,那能转移到它的位置也一定是1
然后再把当前位置的贡献加上
*/
#include <bits/stdc++.h> #define MOD 991127 using namespace std ; int n ; const int MAXN = ; int a[MAXN]; int f[] ; int dp[MAXN] ; inline void update(int &a, int b) {
a += b ;
if (a >= MOD) a -= MOD ;
}
int main() { scanf("%d", &n) ;
for (int i = ; i <= n; i ++) {
scanf("%d", &a[i]) ;
} memset(f, , sizeof f); for (int i = ; i < ; i ++) {
if ((a[] >> i) & ) f[i] = ;
}
dp[] = ;
for (int i = ; i <= n; i ++) {
for (int j = ; j < ; j ++) {
if ((a[i] >> j) & ) update(dp[i], f[j]) ;
}
for (int j = ; j < ; j ++) {
if ((a[i] >> j) & ) update(f[j], dp[i]) ;
}
} printf("%d\n", dp[n]) ; }

10.9NOIP模拟题的更多相关文章

  1. 10.13NOIP模拟题

    /* 容斥原理 考虑到a[i]要么不会太大,要么就对答案贡献很小 dfs即可 */ #include<bits/stdc++.h> #define ll long long #define ...

  2. 10.23NOIP模拟题

    叉叉题目描述现在有一个字符串,每个字母出现的次数均为偶数.接下来我们把第一次出现的字母 a 和第二次出现的 a 连一条线,第三次出现的和四次出现的字母 a 连一条线,第五次出现的和六次出现的字母 a ...

  3. 10.12NOIP模拟题(2)

    /* 有谁知道这道题结论是怎么来的? 晚上问问学数学的孩子23333 */ #include<iostream> #include<cstdio> #include<cs ...

  4. 10.12NOIP模拟题(1)

    #include<iostream> #include<cstdio> #include<cstring> #include<queue> #defin ...

  5. 10.11NOIP模拟题(3)

    /* 可以看出,对于一段区间[L,R]如果统计了答案 若a[L]<a[R],那么当右端点往左移时答案不会更优,a[R]>a[L]同理 所以两个指针分别从头尾往中间扫那边小移哪边即可. */ ...

  6. 10.11NOIP模拟题(2)

    /* string水过 */ #include<bits/stdc++.h> #define N 1001 using namespace std; int n,x,y,m,pre; st ...

  7. poj 1008:Maya Calendar(模拟题,玛雅日历转换)

    Maya Calendar Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 64795   Accepted: 19978 D ...

  8. poj 1888 Crossword Answers 模拟题

    Crossword Answers Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 869   Accepted: 405 D ...

  9. sdut 2162:The Android University ACM Team Selection Contest(第二届山东省省赛原题,模拟题)

    The Android University ACM Team Selection Contest Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里 ...

随机推荐

  1. jQuery_DOM学习之------创建节点及节点属性

    DOM创建节点及节点属性 一.创建新的节点并添加到dom中 dom 节点创建的过程(创建节点<元素.属性.文本等>.添加节点的属性.加入到文档中) jQuery创建元素节点的方法: 创建元 ...

  2. MySQL中间件之ProxySQL_读写分离/查询重写配置

    MySQL中间件之ProxySQL_读写分离/查询重写配置 Posted on 2016-12-25 by mark blue, mark Leave a comment MySQL 1.闲扯几句 读 ...

  3. COJ 1163 乘法逆元的求解

    乘法逆元就是求一个 a/b = c(mod m)在已知a%m , b%m 的条件下 求c的解 #include <cstdio> #include <cstring> usin ...

  4. 家的范围 Home on the Range(洛谷 2733)

    题目背景 农民约翰在一片边长是N (2 <= N <= 250)英里的正方形牧场上放牧他的奶牛.(因为一些原因,他的奶牛只在正方形的牧场上吃草.)遗憾的是,他的奶牛已经毁坏一些土地.( 一 ...

  5. ArrayAdapter的使用

    package com.pingyijinren.test; import android.content.Context; import android.view.LayoutInflater; i ...

  6. JQuery判断radio是否选中并获取选中值的示例代码

    这篇文章主要介绍了JQuery判断radio是否选中并获取选中值的方法,代码很简单,但很实用,需要的朋友可以参考下 其他对radio操作功能,以后在添加.直接上代码,别忘记引用JQuery包 ? 1 ...

  7. AtCoder Grand Contest 011 E - Increasing Numbers(灵性乱搞)

    题意: 当一个整数高位数字总不小于低位数字,或者说写成字符串之后单调不下降,称之为上升数.求一个整数最少能表示为多少个上升数的和.(n<=1e500000) 分析: 考虑那些不下降的数字,一定可 ...

  8. 更新数据库中数据时出现: Error Code: 1175. You are using safe update mode and you tried to update a table without a WHERE that uses a KEY column To disable safe mode, toggle the option in Preferences 问题

    使用workbench在数据库中更新数据时报错: You are using safe update mode and you tried to update a table without a WH ...

  9. Redis Cluster集群搭建后,客户端的连接研究(Spring/Jedis)(待实践)

    说明:无论是否已经搭建好集群,还是使用什么样的客户端去连接,都是必须把全部IP列表集成进去,然后随机往其中一个IP写. 这样做的好处: 1.随机IP写入之后,Redis Cluster代理层会自动根据 ...

  10. CentOS6 设置AliNetflow 环境

    CentOS6 设置AliNetflow 环境 Install OS 这一步略过. 只要保证操作系统是CentOS6.4 并且网络通畅 Install Python2.7.8 设置YUM 我的网络环境 ...