第一题: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的更多相关文章

  1. 牛客NOIP暑期七天营-提高组1

    牛客NOIP暑期七天营-提高组1 链接 A 边权可为0就排序建一条链子. 但是边权不为0 除了第一个有0的不行. x连向上一个比他小的数. 期间判断有无解. #include <bits/std ...

  2. 牛客NOIP暑期七天营-提高组6

    目录 A-积木大赛 题目描述 link 题解 代码 B-破碎的序列 题目描述 link 题解 C-分班问题 题目描述 link 题解 比赛链接 官方题解 A-积木大赛 题目描述 link 题解 标签: ...

  3. 牛客NOIP暑期七天营-提高组5+普及组5

    ————提高组———— 第一题:deco的abs 题目链接:https://ac.nowcoder.com/acm/contest/934/A 因为每个数都可以加任意次 d ,所以可以推出 0 < ...

  4. 牛客NOIP暑期七天营-提高组3

    第一题:破碎的矩阵 题目链接:https://ac.nowcoder.com/acm/contest/932/A    刚看到这题的时候感觉特别熟悉...诶,这不就是codeforces某场比赛的某某 ...

  5. 牛客NOIP暑期七天营-提高组6C:分班问题 (组合数)

    题意:A班有N个人,B班有M个人,现在要组成一个新的班级C班,为了公平,从AB班各抽相同人数的人. 现在求所有方案中,人数之和是多少. 思路:即求Σ k*C(N,k)*C(M,k);    先忽略这个 ...

  6. 牛客NOIP暑期七天营-提高组5

    A:deco的abs. 水题,先%,然后相邻两个数min()一下差值. #include<bits/stdc++.h> #define ll long long using namespa ...

  7. 牛客NOIP暑期七天营-提高组2C:滑块(平衡树) (这里rope骗分)

    A:hash 或者 map 或者trie. #include<bits/stdc++.h> #define rep(i,a,b) for(int i=a;i<=b;i++) usin ...

  8. 牛客NOIP暑期七天营-提高组1 解题报告

    https://ac.nowcoder.com/acm/contest/920#question A 构造+双指针 发现m的限制是1e5,而点数是5e4,所以不能构造太多的边,思考一下最短路树的定义. ...

  9. 牛客NOIP暑期七天营-普及组2D

    链接:https://ac.nowcoder.com/acm/contest/926/D来源:牛客网 在一维坐标系中,给定 n条有颜色的线段,第 i条线段的左右端点分别为 li​和 ri​,此外它的颜 ...

随机推荐

  1. Java开发中常用jar包整理及使用

    本文整理了我自己在Java开发中常用的jar包以及常用的API记录. <!-- https://mvnrepository.com/artifact/org.apache.commons/com ...

  2. 树莓派4B安装netcore

    准备材料 SDFormatter.exe ---格式化SD卡,空的SD就可以不用了 2019-09-26-raspbian-buster.img ---下载好树莓派系统镜像 win32diskimag ...

  3. windows下的nginx应用

    nginx(背景) nginx是一个高性能的HTTP服务器,以前我经常在linux系统中配置,主要做反向代理和负载均衡,最近根据业务需要,需要在window中配置反向和负载,下面就介绍一下nginx的 ...

  4. Python 信息提取-爬虫

    import requests import re from bs4 import BeautifulSoup url = "http://python123.io/ws/demo.html ...

  5. 个人收藏--未整理—C# http/https 上传下载文件

    c# HTTP/HTTPS 文件上传. 分类: .net 2015-02-03 08:36 541人阅读 评论(0) 收藏 举报 方法主体 [csharp] view plaincopy public ...

  6. Java核心技术第八章-泛型

    摘要 本文根据<Java核心技术 卷一>一书的第八章总结而成,部分文章摘抄书内,作为个人笔记. 文章不会过于深入,望读者参考便好. 为什么要使用泛型程序设计 泛型程序设计(Generic ...

  7. php之自动加载(懒加载)

    有A类和B类,如果在A类实例化B类,最简单直接的方法就是在B中使用include require_once A的文件,但是这种方法显然是不友好的,在框架中叶不是这么做的,在框架中使用的是自动加载的机制 ...

  8. https揭秘

    首先简要说明一下所谓的https证书是什么东西:打个比方,你第一次去银行办理业务的时候都需要手持本人身份中去办理业务,这个身份证从哪里来呢,没错,是从国家相关机关得来的,在中国内是通用的,类比到htt ...

  9. spring boot 一个项目启动多个实例

    0.前言 在开发中,我们经常需要以不同端口启动同一个项目的多个实例,IDEA中启动多个实例很简单 1.方法 1.1.在项目中,选择编辑配置,然后点选允许并行运行,如下图: 1.2.调出RunDashb ...

  10. PyCharm 2019.3激活破解教程(永久)

    2019.12.02 jetbrains公司发布了Python的最强编辑器PyCharm 2019.3版本.本次大版本主要对Jupyter notebooks .MongoDB.Python3.8功能 ...