第一题: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. ASP使用ajax来传递中文参数的编码处理

    背景 asp的第一版是0.9测试版,自从1996年ASP1.0诞生,迄今20余载.虽然asp在Windows2000 IIS服务5.0所附带的ASP 3.0发布后好像再没有更新过了,但是由于其入手简单 ...

  2. mysql8.0.13安装、使用教程图解

    mysql8.0.13安装.使用教程图解 MySQL是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS (Relational Database Manageme ...

  3. 【Luogu P1631】序列合并

    Luogu P1631 题意很好懂,不作分析 很容易想出一个解法是求出每一个和,排序后取前n个. 当然这种做法妥妥的会MLE+TLE 我们会发现实质上这种做法的缺点在于存入了大量不需要的数据. 那么该 ...

  4. Bash Shell编程简记

    Shell编程简记 经常在linux环境下开发的同学,难免要使用shell的一些命令或者编写小的脚本,我这里也总结和整理下,自己对Shell的理解和常用的一些shell脚本. 按照目录分为如下3个节: ...

  5. desc和show

    desc只能查看表结构 查看zx1表结构 desc zx1; mysql> desc zx1 -> ; +---------+---------+------+-----+-------- ...

  6. Django2.2 Templates 页面渲染 数据列表跳转 以及简单的页面模块继承

    声明:本博客用的为pycharm Django2.2,基于此内容,会简单讲解 数据库传参形式的增删查改(完整小项目) 路由的 位置参数.关键字参数.以及html中反向解析路由 request的表单传递 ...

  7. 转载一篇关于tab键与focus的文章

    Focusable HTML 元素中,并不是所有元素都可以获得焦点,有如下元素可以获得焦点: a, area, button, input, object, select, textarea,这些元素 ...

  8. PHP常用字符串函数总结

    PHP语言中的字符串函数也是一个比较易懂的知识.今天我们就为大家总结了将近12种PHP字符串函数,希望对又需要的朋友有所帮助,增加读者朋友的PHP知识库. 1.查找字符位置函数 strpos($str ...

  9. 【Elasticsearch 7 探索之路】(五)搜索相关 Search-API

    本节主要讲解 Elasticsearch 的 搜索相关功能 Search-API,讲解什么是 URL Search 和 Request Body Search 的语法,对常用的语法都会一一进行详细介绍 ...

  10. luogu P1801 【黑匣子_NOI导刊2010提高(06)】

    这里提供一个简单实现新思路: . 约定: 以下n指代的数的数量,不是题目所指的n 以下m指代询问的数量,不是题目所指的m (不好意思,这是本人习惯) 分块+堆 **堆一次只能输出堆顶的一个元素,如果我 ...