牛客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,此外它的颜 ...
随机推荐
- JVM的内存回收机制
垃圾回收机制,简称gc.对堆与方法区的对象进行回收,因为java不像c需要编程人员手动clear,虚拟机通过垃圾回收算法,对堆与方法区的对象进行自动回收处理. 1.引用计数法(jvm没有采用,因为当两 ...
- 达梦"记录超长"警告
出现"记录超长"背景介绍: 导入数据库时,出现数据库记录超长警告,导致数据无法正常导入! 1.重新建库,把页大小改大 这种方式是在建立数据库实例的时候进行的 修改[页大小] 2.把 ...
- Roarctf 几道pwn 复现
1.easy_pwn 可以利用的点: __int64 __fastcall sub_E26(signed int a1, unsigned int a2) { __int64 result; // r ...
- Linux -- 进程间通信之管道
管道是 Linux 里的一种文件类型,同时也是 Linux 系统下进程间通信的一种方式 创建一个管道文件有两种方式: Shell 下命令 mkfifo + filename,即创建一个有名管道 ...
- 为宇宙第一强的IDE干一票
背景 在博客园看到很多人说.net在国内已死,很多人在为.net前途担忧,包括一些创业大佬也提及到这些问题,提及到客户指定了说使用php或者java. 那么基本可以确认了,.net 处于风雨漂泊的地位 ...
- Hbase初识
简介 数据模型 相关数据库 典型应用 优势 劣势 key-value Redis 缓存 快速查询 存储数据缺乏结构化 列族 Cassandra,Hbase 分布式的文件系统,大规模的数据存储 易于分布 ...
- CSS 使用id属性的规则
html中的id属性是什么?本篇文章给大家带来的内容是介绍html中的id属性,让大家了解id属性的使用方法,希望对大家有所帮助. html的id属性是什么? html的id属性其实就是一个HTML元 ...
- Yii2 负载均衡找不到JS,CSS
在部署项目的时候,用了2台服务器.请求的时候用了负载均衡,导致 YII2 的静态文件(js,css...)报 404 ,原因是: 请求一个页面时 A服务器 去处理,但是静态资源缺请求到了 B服务器 , ...
- 程序员修神之路--打通Docker镜像发布容器运行流程
菜菜哥,我看了一下docker相关的内容,但是还是有点迷糊 还有哪不明白呢? 如果我想用docker实现所谓的云原生,我的项目该怎么发布呢? 这还是要详细介绍一下docker了 Docker 是一个开 ...
- nginx部署安装
首先需要下载Nginx软件包 nginx软件官方下载地址:[nginx官方下载连接](http://www.nginx.org) 建议选择稳定的软件版本,如果练习使用当然是无所谓,随便什么版本都可以, ...