河南理工大学第十届校赛

很久没有组队打比赛了,好吧应该说很久没有写题了,

三个人一起玩果然比一个人玩有趣多了。。。

前100分钟过了4题,中途挂机100分钟也不知道什么原因,可能是因为到饭点太饿了?,最后100分钟一人开一题差点冲到榜首也太刺激了吧!

是一次愉快的游戏体验。

下周去农大参加邀请赛,希望能和今天一样快乐~



今天是冬至,别忘记吃饺子!



题解和代码

A. Dong Zhi

A题地址

题意:输出"Let's eat dumplings",这句话

思路:看标题肯定签到了,但是hpu前5分钟好卡,网速拼不过。

#include<bits/stdc++.h>
using namespace std; int main(){
cout<<"Let's eat dumplings"<<endl;
return 0;
}

##B. The flower
[B题地址](https://hpuoj.com/contest/32/problem/B/)
题意:统计字符串中 出现次数>2的,长度为T的子串。从小到大按字典序输出子串。
思路:用unorder_map统计子串出现的次数。substr(i,k)截取字符串。
```
#include
#include
using namespace std;

string s;

string flower = "flower";

int k;

unordered_map<string,int >mp;

vector ans;

int main(){

cin>>s>>k;

int len = s.length();

string temp;

for(int i=0;i+k<=len;i++){

temp = s.substr(i,k);

mp[temp]++;

}

unordered_map<string,int >:: iterator it = mp.begin();

while(it != mp.end()){

if(it->second > 2) ans.push_back(it->first);

it++;

}

sort(ans.begin(),ans.end());

printf("%d\n",ans.size());

for(int i=0;i<ans.size();i++) printf("%s\n",ans[i].c_str());

return 0;

}

<br/>

##C. Xor Path
[C题地址](https://hpuoj.com/contest/32/problem/C/)
题意:一颗树,Q次查询,求两个结点最小的异或和。
思路:求最近公共祖先,dfs求每个结点到根节点1的路径异或和,lca优化,复杂度qlogn

include<bits/stdc++.h>

using namespace std;

typedef long long ll;

const int maxn = 1e6+100;

vector g[maxn];

int pre[maxn],a[maxn],parent[maxn],f[maxn][30],depth[maxn];

ll bit[30];

//初始化bit数组:求2的i次幂

void init(){

bit[0] = 1;

for(int i=1;i<=29;i++){

bit[i] = (bit[i-1]<<1);

}

}

void dfs(int u,int par){

depth[u] = depth[par] + 1;

f[u][0] = par;

for(int i=1;bit[i]<=depth[u];i++) f[u][i] = f[f[u][i-1]][i-1];

for(int v:g[u]){

if(v!=par) dfs(v,u);

}

}

//求x和y的最近公共祖先

int lca(int x,int y){

if(depth[x] < depth[y]) swap(x,y);

for(int i=29;i>=0;i--){

if(depth[x] - depth[y] >= bit[i]) x = f[x][i];

}

if(x == y) return x;

for(int i=29;i>=0;i--){

if(depth[x] >= (1<<i) && f[x][i] != f[y][i]){

x = f[x][i];

y = f[y][i];

}

}

return f[x][0];

}

void DFS1(int u,int fa){

parent[u] = fa;

pre[u] = pre[fa]^a[u];

for(int v:g[u]){

if(v == fa) continue;

DFS1(v,u);

}

}

int main(){

int n,u,v,q;

//输入数据

cin>>n;

for(int i=1;i<=n;i++) cin>>a[i];

init();

//建图 邻接表

for(int i=0;i<=n;i++) g[i].clear();

for(int i=1;i<=n-1;i++){

cin>>u>>v;

g[u].push_back(v);

g[v].push_back(u);

}

dfs(1,0);

//dfs计算从根节点到每个结点的异或和

DFS1(1,0);

int x,y;

cin>>q;

while(q--){

cin>>x>>y;

int c = lca(x,y); //求x,y的最近公共祖先

int f = parent[c]; //求最近公共祖先的父节点 这里再求一次父节点的原因是: 消除祖先的父节点到根节点这段路径(异或了2次)的异或

cout<<(pre[x]pre[y]pre[f]^pre[c])<<endl; //画图理解 树链上异或两次就等于没有异或 消除祖先的父节点到根节点这段路径(异或了2次)的异或

}

return 0;

}


##D. LaunchPad
[D题地址](https://hpuoj.com/contest/32/problem/D/)
题意:翻转pad,每次翻转第x一整行和第y一整列,求Q次后最终翻转为亮面的个数
思路:队友过的。。似乎开两个一维数组,一个统计行,一个统计列,判断奇偶就可以了

include

include

include

include

include

using namespace std;

int mp[1005][1005];

int main(){

int m,n;cin>>n>>m;

int q;cin>>q;

int visX[1005];

int visY[1005];

memset(visX,0,sizeof(visX));

memset(visY,0,sizeof(visY));

while(q--){

int x,y;

cin>>x>>y;

visX[x]++;

visY[y]++;

mp[x][y]++;

}

int ans = 0;

for(int i = 1;i<=n;i++){

for(int j = 1;j<=m;j++){

if((visX[i]+visY[j]+mp[i][j])%2!=0){

ans++;

}

}

}

cout<<ans;

return 0;

}

<br/>

##E. Morse code
[E题地址](https://hpuoj.com/contest/32/problem/E/)
题意:给一个字符串,找最长可以匹配莫斯码成功的字母长度。
思路:这。。队友过的,我题目还没看完,他就过了。等等??看了看他代码,也太秀了。

include

include

include

include

include

include

include<string.h>

include

include

using namespace std;

typedef long long ll;

const int maxn =2e5+10;

const ll N=1e9+7;

bool flag;

int main()

{

int t;

cin >> t;

while(t--)

{

string s;

cin >> s;

ll ans=s.size()/2; //这样就行了嘛??

cout << ans << endl;

}

return 0;

}

<br/>
##F. For language
[F题地址](https://hpuoj.com/contest/32/problem/F/)
题意:计算时间复杂度。
思路:一行一行读,看第一个输入的字符串是什么就,按什么来

include<bits/stdc++.h>

using namespace std;

typedef long long ll;

const ll mod = 1e9+7;

int n;

ll get(string x,string y){

ll xx = 0;

for(int i=0;i<x.length();i++){

xx = xx10 + (x[i] - '0');

}

ll yy = 0;

for(int i=0;i<y.length();i++){

yy = yy
10 + (y[i] - '0');

}

return (yy - xx + 1) % mod;

}

int main(){

cin>>n;

bool develop = 0;

ll ans = 0;

ll value = 0;

for(int line=1;line<=n;line++){

string first;

cin>>first;

if(first == "begin"){

develop = 1;

value = -1;

}else if(first == "for" && develop==1){

string a;

cin>>a;

string num1;

cin>>num1;

string num2;

cin>>num2;

ll cur = get(num1,num2)%mod;

//判断等于0的情况

if(value == -1) value = 1;

value = (value * cur) % mod;

}else if(first == "end"){

develop = 0;

if(value != -1)

ans = (ans + value)%mod;

}

}

cout<<ans;

return 0;

}

<br/>

##G. Puzzle
[G题地址](https://hpuoj.com/contest/32/problem/G/)
题意:累加一个数每一位上的cycle值,其中1, 2, 3, 5, 7 have 0 cycle, 4, 6, 9 have 1 cycle and 8 has 2 cycles.
思路:看懂样例,就可以直接做了

include<bits/stdc++.h>

using namespace std;

typedef long long ll;

int t;

int a[10] = {1,0,0,0,1,0,1,0,2,1};

int main(){

cin>>t;

while(t--){

ll x;

cin>>x;

ll temp = x;

int ans = 0;

while(temp){

ans+=a[temp%10];

temp/=10;

}

cout<<ans<<endl;

}

return 0;

}

<br/>
##H. Triangle tower
[H题地址](https://hpuoj.com/contest/32/problem/H/)
不是动态规划,队友过的,组合数,和杨辉三角有关。
放上队友在地铁上画的两张图。。。
![](https://img2018.cnblogs.com/blog/1454456/201912/1454456-20191222164640056-1834506144.png)
![](https://img2018.cnblogs.com/blog/1454456/201912/1454456-20191222164719199-1709997521.png)

include

include

include

include

include

using namespace std;

const int mod = 1e9+7;

const int maxn = 1e5+5;

typedef long long ll;

ll c[maxn];//组合数 1 1e5

ll fac[maxn];

ll inv[maxn];

ll qpow(long long a,long long b)

{

ll ans=1;

ll k=a;

while(b)

{

if(b&1)ans=ansk%mod;

k=k
k%mod;

b>>=1;

}

return (ans+mod)%mod;

}

void init(){

long long i;

fac[0]=1;

inv[0]=1;

fac[1]=1;

inv[1]=1;

for (i=2;i<maxn;i++){

fac[i]=((fac[i-1]i)%mod+mod)%mod;

inv[i]=(qpow(fac[i],mod-2)+mod)%mod;

}

}

ll C(ll n,ll m){

if (n<m||m<0) return 0;

return (fac[n]
inv[m]%modinv[n-m]%mod+mod)%mod;

}

int main(){

int t;

cin>>t;

init();

while(t--){

int m,n;

cin>>n>>m;

ll ans;

if(m%2 == 1){

m = m/2+1;

m--;

n--;

int t = n - m;

ans = C(n,m);

}

else{

m = m/2;

m--,n-=2;

int t = n - m;

//cout<<c[n]<<" "<<c[m]<<" "<<c[t];

ll t1 = (c[m]
c[t])%mod;

ans = C(n,m);

}//用上一行

cout<<ans<<endl;

}

return 0;

}

<br/>
##I. Kingdom of Mathematics
[I题地址](https://hpuoj.com/contest/32/problem/I/)
没做,还不会。
<br/>
##J. HPU's birthday
[J题地址](https://hpuoj.com/contest/32/problem/J/)
题意:给一个数n,求这个数n的二进制字符串,再把这个二进制字符串循环拼接n次,求最终i,j,k能组成110的组数
思路:我做了半天,思路错了;队友想到可以遍历最终拼接后的字符串,每次出现0,就统计前面有多少个1,选出两个1就可以了。比如前面出现了x个1,就计算C(x,2)
所以最后用了 前缀和,AC了,但是不要忘了开longlong,乘法会溢出!!wa了7次就这个原因。。怪自己很久没写代码细节都忘了。

include<bits/stdc++.h>

using namespace std;

typedef long long ll;

const ll mod = 1e9+7;

//const ll maxn = 2e6+10;

const int maxn = 1700000;

ll C[maxn];

int t;

ll n;

vector vec;

vector v;

vector ans;

void cov(ll x){

vec.clear();

v.clear();

if(x == 0) {

v.push_back(0);

return;

}

while(x){

vec.push_back(x%2);

x = x/2;

}

for(int i=vec.size()-1;i>=0;i--) v.push_back(vec[i]);

}

void init(){

for(ll i=1;i<=maxn;i++){

C[i] = ((i*(i-1))/2)%mod;

}

}

ll a[maxn];

int main(){

init();

cin>>t;

while(t--){

cin>>n;

cov(n);

ans.clear();

ans.push_back(0);

for(ll i=1;i<=n;i++){

for(int j=0;j<v.size();j++) ans.push_back(v[j]);

}

a[0] = 0;

for(int i=1;i<ans.size();i++){

if(ans[i] == 1) a[i] = a[i-1]+1;

else a[i] = a[i-1];

}

int len = ans.size();

ll answer = 0;

for(int i=1;i<len;i++){

if(ans[i] == 0){

answer = (answer + C[a[i]])%mod;

}

}

cout<<answer%mod<<endl;

}

return 0;

}

<br/>

##K. Max Sum
[K题地址](https://hpuoj.com/contest/32/problem/K/)
思路:两颗线段树:tp维护最小前缀和,tn维护最小后缀和
要计算[L,R]上的最大区间和,(其中 L<=i,R<=i+ki,L<=R)
只需要求出区间[i-ki-1,i-1]的最小前缀和 和 区间[i+1,i+ki+1]的最小后缀和
数组总和减去这两部分的值就是第i个位置上的最大wonderful interval

include<bits/stdc++.h>

using namespace std;

define ll long long

const int maxn=1000000+10;

const int INF=0x3f3f3f3f;

int a[maxn];

ll pre[maxn],nxt[maxn];

int k[maxn];

int N;

//线段树单点更新区间求和

struct Tree{

ll x[maxn];

//初始化

void init(int x){

N=1;

while(N<=x2) N=2;

}

//单点更新

void update(int k,int q){

k+=N-1;

x[k]=q;

while(k){

k=(k-1)/2;

x[k]=min(x[k2+1],x[k2+2]);

}

}

//区间查询

ll query(int a,int b,int l,int r,int k){

if(r<a || b<l) return INF; //处理边界

if(a<=l && r<=b) return x[k]; //处理边界

else{

ll vl=query(a,b,l,(l+r)/2,k2+1);

ll vr=query(a,b,(l+r)/2+1,r,k
2+2);

return min(vl,vr);

}

}

}tp,tn;

int main(){

int n;

scanf("%d",&n);

for(int i=1;i<=n;i++) scanf("%d",&k[i]);

tp.init(n);

//前缀和 建线段树

ll sum=0;

for(int i=1;i<=n;i++){

scanf("%d",&a[i]);

sum+=a[i];

tp.update(i,sum);

}

//后缀和 建线段树

sum=0;

for(int i=n;i>=1;i--){

sum+=a[i];

tn.update(i,sum);

}

//i从1~n sum为数组总和 定义的最大区间值 就=sum-最小前缀-最小后缀

ll ans=0;

for(int i=1;i<=n;i++){

ans+=sum;

ans-=tp.query(max(i-k[i]-1,0),max(i-1,0),0,N-1,0);

ans-=tn.query(min(i+1,n+1),min(i+k[i]+1,n+1),0,N-1,0);

}

printf("%lld\n",ans);

return 0;

}


##L. Restore Expressions
思路:两个始自终除第一个数a,b外其它全取1,另表达式右端=0,计算使a,b恢复到正数的最大次数。

写完代码就去吃饺子|The 10th Henan Polytechnic University Programming Contest的更多相关文章

  1. sublime安装LiveReload(写完代码再也不用手动刷新浏览器了)【转】

    1.首先在chrome下安装这个扩展程序 LiveReload 2.在sublime下按快捷键 ctrl+shift+p  点击截图标的位置 按回车 输入LiveReload 即可下载 然后打开 {改 ...

  2. html文件在head标签中引入js地址和直接写js代码,所用时间是不同的,因为引入js地址,文件加载的时候需要通过通讯协议去解析地址,读取外部文件

    html文件在head标签中引入js地址和直接写js代码,所用时间是不同的,因为引入js地址,文件加载的时候需要通过通讯协议去解析地址,读取外部文件

  3. jQuery之父:每天都写点代码

    去年秋天,我的“兼职编程项目”遇到了一些问题:要不是从 Khan Academy 的项目里挪出时间来的话,我根本没办法将不理想的进度弥补上. 这些项目遇到了一些严重的问题.之前的工作我主要是在周末,有 ...

  4. [Swust OJ 603]--吃饺子大王

      题目链接:http://acm.swust.edu.cn/problem/603/ Time limit(ms): 1000 Memory limit(kb): 65535   同学们还记得我们班 ...

  5. 朱晔的互联网架构实践心得S2E2:写业务代码最容易掉的10种坑

    我承认,本文的标题有一点标题党,特别是写业务代码,大家因为没有足够重视一些细节最容易调的坑(侧重Java,当然,本文说的这些点很多是不限制于语言的). 1.客户端的使用 我们在使用Redis.Elas ...

  6. QBXT Day2主要是数据结构(没写完先占坑)

    简单数据结构 本节课可能用到的一些复杂度: O(log n). 1/1+1/1/.....1/N+O(n log n) 在我们初学OI的时候,总会遇到这么一道题. 给出N次操作,每次加入一个数,或者询 ...

  7. 不写完不让回家的JQuery的事件与动画

    在这看不见太阳的小黑屋里,苦逼的一天又开始了 好了闲话我也就不扯了,接下来我就来说说我对jQuery事件和动画的理解吧!!! 还是得再扯两句,我们敬爱的,Y老师讲完了,jQuery事件和动画,对着我们 ...

  8. C# 超高速高性能写日志 代码开源

    1.需求 需求很简单,就是在C#开发中高速写日志.比如在高并发,高流量的地方需要写日志.我们知道程序在操作磁盘时是比较耗时的,所以我们把日志写到磁盘上会有一定的时间耗在上面,这些并不是我们想看到的. ...

  9. 不写一行代码,利用常用工具和软件批量下载URL资源

    有时候会遇到这种情况:想从某个网站下载一批东西,目标URL是比较规整的,而且结构都一样(仅某些字段不同).但又懒得开IDE专门写个脚本去弄,今天就和大家分享一下,如何利用手边常用的软件和工具,不用写一 ...

随机推荐

  1. 【Android - IPC】之AIDL简介

    参考资料: 1.<Android开发艺术探索>第二章2.4.4 2.Android AIDL Binder框架解析:http://blog.csdn.net/lmj623565791/ar ...

  2. ansible roles 介绍和使用

    目录 roles roles 介绍 创建role的步骤 role内个目录中可用的文件 案例 roles roles 介绍 ansible 自1.2版本引入的新特性,用于层次性.结构化地组织playbo ...

  3. 【BZOJ4001】【Luogu P3978】 [TJOI2015]概率论

    题目描述: Description: Input 输入一个正整数N,代表有根树的结点数 Output 输出这棵树期望的叶子节点数.要求误差小于1e-9 Sample Input 1 Sample Ou ...

  4. 谁说微服务是Spring Cloud的独角戏?Service Mesh了解一下?

    Service Mesh 的概念自 2017 年初提出之后,受到了业界的广泛关注,作为微服务的下一代发展架构在社区迅速发酵,并且孵化出了诸如 Istio 等广受业界关注的面向于云原生 (Cloud N ...

  5. luogu P3939 数颜色 |vector

    题目描述 小 C 的兔子不是雪白的,而是五彩缤纷的.每只兔子都有一种颜色,不同的兔子可能有 相同的颜色.小 C 把她标号从 1 到 n 的 n 只兔子排成长长的一排,来给他们喂胡萝卜吃. 排列完成后, ...

  6. 设计模式GOF23(创建型模式)

    • 创建型模式:  单例模式.工厂模式.抽象工厂模式.建造者模式.原型模式.   • 结构型模式: –适配器模式.桥接模式.装饰模式.组合模式.外观模式.享元模式.代理模式.   • 行为型模式: 模 ...

  7. Spring Boot Validation,既有注解不满足,我是怎么暴力扩展validation注解的

    前言 昨天,我开发的代码,又收获了一个bug,说是界面上列表查询时,正常情况下,可以根据某个关键字keyword模糊查询,后台会去数据库 %keyword%查询(非互联网项目,没有使用es,只能这样了 ...

  8. CF579 - A Raisinng bacteria

    You are a lover of bacteria. You want to raise some bacteria in a box. Initially, the box is empty. ...

  9. ARTS-S golang函数作为参数传递

    函数作为参数传递在单元测试的时候非常有用,看下面的例子. package main import "fmt" func output(f func(string, string, ...

  10. spring源码学习之设计模式(1)单例模式

    众所周知,单例模式分为饿汉式和懒汉式,昨天在看了<spring5核心原理与30个类手写实战>之后才知道饿汉式有很多种写法,分别适用于不同场景,避免反射,线程不安全问题.下面就各种场景.采用 ...