牛客NOIP暑期七天营-提高组2
第一题:ACGT
题目链接:https://ac.nowcoder.com/acm/contest/931/A
trie树、hash、map遍历
①、trie树上的节点多记一个rest值表示还有多少个串没被用。枚举所有串, 每次先在trie上跑匹配串,看一看那个点的rest。如果没法匹配的话就往trie里插入原串,把结束节点的rest+1
②、思路和trie类似。其实就是把trie换成hash。(把在树上跑换成去hash值)
③、将每个序列的个数存下,每次读入时判断对应序列的map的权值是否为0,若不为0,将输入序列和其对应序列的map权值-- ,ans++
下面是第三种解法 :
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 0x3f3f3f
ll read()
{
ll res=,flag=;
char ch;
if((ch=getchar())=='-')flag=;
else if(ch>=''&&ch<='')res=ch-'';
while((ch=getchar())>=''&&ch<='')res=res*+(ch-'');
return flag?-res:res;
}
void out(int a)
{
if (a<)
{
putchar('-');
a=-a;
}
if(a>=)out(a/);
putchar(a%+'');
}
map<string ,int >haha;
int n;
map<char,char> ab;
int main()
{
ios_base::sync_with_stdio(false);
ab['A'] = 'T';
ab['T'] = 'A';
ab['C'] = 'G';
ab['G'] = 'C';
while(cin>>n)
{
string a;
string b;
int cot = ;
haha.clear();
for(int i=; i<=n; i++)
{
cin>>a;
haha[a]++;
b="";
for(int i = ; i < a.size(); i++)
{
b+=ab[a[i]];
}
// cout<<b<<" "<<haha[b]<<endl;
if(haha[b]!=)
{
cot++;
haha[b]--;
haha[a]--;
}
}
cout<<cot<<endl;
}
return ;
}
第二题:幸运数字考试
题目链接:https://ac.nowcoder.com/acm/contest/931/B
dfs打表+二分
因为n是<=1e19的,而long long是存不到大于777777777444444444的下一个幸运数,所以当n>777777777444444444,我们要进行特判。
剩下的情况的最大的幸运数则为777777777444444444。
因为幸运数肯定为偶数,且只包含4、7且4、7个数相同,所以打表完我们会发现 在long long可存的范围下幸运数并不多
所以我们将所有幸运数存入arr[ ]数组中,最后再对arr[ ]和n进行二分查找,返回大于等于n的第一个幸运数(打表时注意递归方式使数组arr[ ]默认从小到大排序)
下面贴代码:
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 0x3f3f3f
ll read()
{
ll res=,flag=;
char ch;
if((ch=getchar())=='-')flag=;
else if(ch>=''&&ch<='')res=ch-'';
while((ch=getchar())>=''&&ch<='')res=res*+(ch-'');
return flag?-res:res;
}
void out(ll a)
{
if (a<)
{
putchar('-');
a=-a;
}
if(a>=)out(a/);
putchar(a%+'');
}
const int N = 1e6+;
int k = ,t;
ll n;
ll arr[N];
void dfs(int num4,int num7,ll ans)
{
if(num4 == && num7 == )
{
arr[k++] = ans;
return ;
}
else if(num4 == )
{
dfs(num4,num7-,ans*+);
}
else if(num7 == )
{
dfs(num4-,num7,ans*+);
}
else
{
dfs(num4-,num7,ans*+);
dfs(num4,num7-,ans*+);
}
}
int main()
{
ios::sync_with_stdio(false);
for(int i=; i<=; i+=)
dfs(i/,i/,);
k--;
cin>>t;
while(t--)
{
cin>>n;
if(n > )
{
cout<<""<<endl;
continue;
}
int r = k;
int l = ;
while(r - l > )
{
int mid = (r+l)>>; if(arr[mid]<n)
l = mid + ;
else
r = mid;
}
cout<<arr[r]<<endl;
}
return ;
}
牛客NOIP暑期七天营-提高组2的更多相关文章
- 牛客NOIP暑期七天营-提高组1
牛客NOIP暑期七天营-提高组1 链接 A 边权可为0就排序建一条链子. 但是边权不为0 除了第一个有0的不行. x连向上一个比他小的数. 期间判断有无解. #include <bits/std ...
- 牛客NOIP暑期七天营-提高组6
目录 A-积木大赛 题目描述 link 题解 代码 B-破碎的序列 题目描述 link 题解 C-分班问题 题目描述 link 题解 比赛链接 官方题解 A-积木大赛 题目描述 link 题解 标签: ...
- 牛客NOIP暑期七天营-提高组5+普及组5
————提高组———— 第一题:deco的abs 题目链接:https://ac.nowcoder.com/acm/contest/934/A 因为每个数都可以加任意次 d ,所以可以推出 0 < ...
- 牛客NOIP暑期七天营-提高组3
第一题:破碎的矩阵 题目链接:https://ac.nowcoder.com/acm/contest/932/A 刚看到这题的时候感觉特别熟悉...诶,这不就是codeforces某场比赛的某某 ...
- 牛客NOIP暑期七天营-提高组6C:分班问题 (组合数)
题意:A班有N个人,B班有M个人,现在要组成一个新的班级C班,为了公平,从AB班各抽相同人数的人. 现在求所有方案中,人数之和是多少. 思路:即求Σ k*C(N,k)*C(M,k); 先忽略这个 ...
- 牛客NOIP暑期七天营-提高组5
A:deco的abs. 水题,先%,然后相邻两个数min()一下差值. #include<bits/stdc++.h> #define ll long long using namespa ...
- 牛客NOIP暑期七天营-提高组2C:滑块(平衡树) (这里rope骗分)
A:hash 或者 map 或者trie. #include<bits/stdc++.h> #define rep(i,a,b) for(int i=a;i<=b;i++) usin ...
- 牛客NOIP暑期七天营-提高组1 解题报告
https://ac.nowcoder.com/acm/contest/920#question A 构造+双指针 发现m的限制是1e5,而点数是5e4,所以不能构造太多的边,思考一下最短路树的定义. ...
- 牛客NOIP暑期七天营-普及组2D
链接:https://ac.nowcoder.com/acm/contest/926/D来源:牛客网 在一维坐标系中,给定 n条有颜色的线段,第 i条线段的左右端点分别为 li和 ri,此外它的颜 ...
随机推荐
- Java开发中常用jar包整理及使用
本文整理了我自己在Java开发中常用的jar包以及常用的API记录. <!-- https://mvnrepository.com/artifact/org.apache.commons/com ...
- 树莓派4B安装netcore
准备材料 SDFormatter.exe ---格式化SD卡,空的SD就可以不用了 2019-09-26-raspbian-buster.img ---下载好树莓派系统镜像 win32diskimag ...
- windows下的nginx应用
nginx(背景) nginx是一个高性能的HTTP服务器,以前我经常在linux系统中配置,主要做反向代理和负载均衡,最近根据业务需要,需要在window中配置反向和负载,下面就介绍一下nginx的 ...
- Python 信息提取-爬虫
import requests import re from bs4 import BeautifulSoup url = "http://python123.io/ws/demo.html ...
- 个人收藏--未整理—C# http/https 上传下载文件
c# HTTP/HTTPS 文件上传. 分类: .net 2015-02-03 08:36 541人阅读 评论(0) 收藏 举报 方法主体 [csharp] view plaincopy public ...
- Java核心技术第八章-泛型
摘要 本文根据<Java核心技术 卷一>一书的第八章总结而成,部分文章摘抄书内,作为个人笔记. 文章不会过于深入,望读者参考便好. 为什么要使用泛型程序设计 泛型程序设计(Generic ...
- php之自动加载(懒加载)
有A类和B类,如果在A类实例化B类,最简单直接的方法就是在B中使用include require_once A的文件,但是这种方法显然是不友好的,在框架中叶不是这么做的,在框架中使用的是自动加载的机制 ...
- https揭秘
首先简要说明一下所谓的https证书是什么东西:打个比方,你第一次去银行办理业务的时候都需要手持本人身份中去办理业务,这个身份证从哪里来呢,没错,是从国家相关机关得来的,在中国内是通用的,类比到htt ...
- spring boot 一个项目启动多个实例
0.前言 在开发中,我们经常需要以不同端口启动同一个项目的多个实例,IDEA中启动多个实例很简单 1.方法 1.1.在项目中,选择编辑配置,然后点选允许并行运行,如下图: 1.2.调出RunDashb ...
- PyCharm 2019.3激活破解教程(永久)
2019.12.02 jetbrains公司发布了Python的最强编辑器PyCharm 2019.3版本.本次大版本主要对Jupyter notebooks .MongoDB.Python3.8功能 ...