10.1综合强化刷题 Day3 morning
竞赛时间:????年??月??日??:??-??:??
题目名称 |
a |
b |
c |
名称 |
a |
b |
c |
输入 |
a.in |
b.in |
c.in |
输出 |
a.out |
b.out |
c.out |
每个测试点时限 |
1s |
1s |
1s |
内存限制 |
256MB |
256MB |
256MB |
测试点数目 |
10 |
10 |
10 |
每个测试点分值 |
10 |
10 |
10 |
是否有部分分 |
无 |
无 |
无 |
题目类型 |
传统 |
传统 |
传统 |
a
【问题描述】
你是能看到第一题的 friends 呢。
——hja
怎么快速记单词呢?也许把单词分类再记单词是个不错的选择。何大爷给出了一种分单词的方法,何大爷认为两个单词是同一类的当这两个单词的各个字母的个数是一样的,如 dog 和 god。现在何大爷给了你 N个单词,问这里总共有多少类单词。
【输入格式】
第一行一个整数N代表单词的个数。接下来N行每行一个单词。
【输出格式】
一行一个整数代表答案。
【样例输入】
3
AABAC
CBAAA
AAABB
【样例输出】
2
本来打的是个70分的暴力,结果后面两个点A了,第8个点T了、、准是看本姑娘太可爱了、、
将近n^2枚举,判断一个字符是否与另一个字母相同,在比较的时候挨个字母的个数进行比较
#include<cstdio> #include<cstring> #include<cstdlib> #include<iostream> #include<algorithm> #define N 10010 using namespace std; bool flag; ]; ],fa[N]; int find(int x) { if(fa[x]==x) return x; return fa[x]=find(fa[x]); } int read() { ,f=; char ch=getchar(); ;ch=getchar();} +ch-',ch=getchar(); return x*f; } int main() { freopen("a.in","r",stdin); freopen("a.out","w",stdout); n=read();ans=n; ;i<=n;i++) cin>>ch[i],l[i]=strlen(ch[i]); // sort() ;i<=n;i++) ;j<l[i];j++) sum[i][ch[i][j]-'A']++; ;i<=n;i++) fa[i]=i; ;i<=n;i++) ;j<=n;j++) { flag=false; ;k<;k++) if(sum[i][k]!=sum[j][k]) {flag=true; break;} if(!flag) if(find(i)!=find(j)) fa[j]=i,ans--; } printf("%d",ans); ; }
考场90分代码
AC代码
将字符串转换成数字进行比较(在转换的时候我们要乘一个质数,乘质数重复的可能性很小),sort排序以后判断当前数是否与他后面的数相同,如果不同ans++
#include<cstdio> #include<cstring> #include<cstdlib> #include<iostream> #include<algorithm> #define N 10010 using namespace std; ]; int n,l[N],ans,num[N]; int read() { ,f=; char ch=getchar(); ;ch=getchar();} +ch-',ch=getchar(); return x*f; } int main() { freopen("a.in","r",stdin); freopen("a.out","w",stdout); n=read(); ;i<=n;i++) { cin>>ch,l[i]=strlen(ch); sort(ch,ch+l[i]); ;j<l[i];j++) num[i]=num[i]*+ch[j]-; } sort(num+,num++n); ;i<n;i++) ]) ans++; printf(); ; }
AC代码
b
【问题描述】
你是能看到第二题的 friends 呢。
——laekov
长度为n 的铁丝,你可以将其分成若干段,并把每段都折成一个三角形。你还需要保证三角形的边长都是正整数并且三角形两两相似,问有多少种不同的分法。
【输入格式】
一行一个整数n 。
【输出格式】
一行一个整数代表答案对109 + 7取模之后的值。
【样例输入 1
6
【样例输出 1】
2
【样例输入 2】
9
【样例输出 2】
6
【样例解释 2】
(1,1,1), (2,2,2); (2,2,2), (1,1,1)算两种方案。
我们假设每一段的长度为Li,g=gcd(Li);
我们用f[i]表示周长为i的能组成的三角形的个数,用sum[n/i]表示将n/i个单位(为什么是n/i个单位,因为现在三角形的周长为i,我们要将n分开,最小的周长单位为i,一共有n/i组这样的周长可以进行分配)分配给任意多个三角形的方案数,g[i]表示我们可以使用的三角形的周长。
我们对于最小的周长可以将它的三条边设为a,b,c,我们设a<=b<=c
接下来我们在处理的时候对b与c的大小关系进行分类讨论,
当b=c的时候
这样b的大小就在(g/3)(上取整)~(g-1)/2(下取整)之间,这样f[g]的大小即为f[g]=floor((g-1)/2)- ceil(g/3) +1
当b<c的时候
这种情况下所有的情况都可以由a,b,c-1的每一种方案转移过来但有一种除外:a+b=c,因为此时a,b,c-1 合法,a,b,c 不合法,这种情况为当g为偶数时,a+b+a+b=g,g=2*(a+b),所以有floor(g/4)个所以f[g]=f[g-1]+ (b&1)? 0 : -g/4
#include<cmath> #include<cstdio> #include<cstring> #include<iostream> #include<algorithm> #define N 1000001 #define mod 1000000007 using namespace std; int n,ans,cnt,f[N],g[N],sum[N]; int read() { ,f=; char ch=getchar(); ;ch=getchar();} +ch-',ch=getchar(); return x*f; } int main() { freopen("b.in","r",stdin); freopen("b.out","w",stdout); n=read(); ;i<=n;i++) { f[i]=f[i-]; f[i]=f[i]%mod+(i->>)%mod-ceil(i*)+;//设a<b<c,当b=c时,g=a+2b,那么b∈[ceil(g/3),floor((g-1)/2)]所以f[g]=floor((g-1)/2)- ceil(g/3) +1 ==) f[i]=f[i]%mod-i/;//当i为偶数的时候,可能会形成a+b=c的这种情况,这是没有值的,g=a+b+c,g=2*(a+b),所以有floor(g/4)个 } ;i*i<=n;i++)//找n的因子 ,处理出g为可以存在的三角形的周长 ) { g[++cnt]=i; if(i*i!=n) g[++cnt]=n/i; } sort(g+,g+cnt+); ;i<=cnt;i++) ;j<i;j++) ) f[g[i]]=(f[g[i]]%mod+(mod-f[g[j]])%mod)%mod;//然后因为要求三边长互质,所以枚举g的每个因数k,f[g]-=f[k] sum[]=; ;i<=n;i++) sum[i]=sum[i-],sum[i]=(sum[i]%mod+sum[i-]%mod)%mod;//把i个物品分成任意份的方案数=C(i-1,0)+C(i-1,1)+……+C(i-1,i-1)= 2^(i-1) ;i<=cnt;i++) ans=(ans%mod+1ll*sum[n/g[i]-]*f[g[i]]%mod)%mod; printf("%d",ans); ; }
AC代码
c
【问题描述】
你是能看到第三题的 friends 呢。
——aoao
在小学的时候,我们都学过正视图和左视图。现在何大爷用一些小方块摆了一个图形,并给出了你这个图形的左视图和正视图。现在何大爷希望知道,在给定正视图和左视图的情况下,原来的立体图形有多少种可能的情况?
【输入格式】
第一行两个整数N ,M ,代表在左视图和正视图中分别有多少列。
第二行N个整数,代表在左视图中从左至右每一列的高度。
第三行M个整数,代表在正视图中从左至有每一列的高度。
【输出格式】
一行一个整数代表答案对109 + 9取模之后的值。
【样例输入 1】
2 2
1 1
1 1
【样例输出 1】
7
【样例输入 2】
4 5
5 2 4 1
5 2 4 0 1
【样例输出 2】
429287
距 NOIp2017 还剩 28 天
你可以做的事情还有很多,即使到最后一秒也不要放弃,因为不到结束的那一刻谁也不知道结果会怎样。
10.1综合强化刷题 Day3 morning的更多相关文章
- 10.1综合强化刷题 Day3 afternoon
竞赛时间:????年??月??日??:??-??:?? 题目名称 a b c 名称 a b c 输入 a.in b.in c.in 输出 a.out b.out c.out 每个测试点时限 1s 1s ...
- 10.1综合强化刷题 Day3
括号序列(bracket) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK有一个括号序列,但这个序列不一定合法. 一个合法的括号序列如下: ()是合法的 ...
- 10.1综合强化刷题 Day2 morning
一道图论神题(god) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK有一张无向图G={V,E},这张无向图有n个点m条边组成.并且这是一张带权图,只有 ...
- 10.1综合强化刷题 Day2 afternoon
最大值(max) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK有一本书,上面有很多有趣的OI问题.今天LYK看到了这么一道题目: 这里有一个长度为n的 ...
- 10.1综合强化刷题 Day7
noip提高组模拟赛 ...
- 10.1综合强化刷题 Day1 afternoon
一道图论好题(graph) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK有一张无向图G={V,E},这张无向图有n个点m条边组成.并且这是一张带权图, ...
- 10.1综合强化刷题 Day6
T1 排序 题目描述 小Z 有一个数字序列a1; a2; .... ; an,长度为n,小Z 只有一个操作:选 定p(1<p<n),然后把ap 从序列中拿出,然后再插⼊到序列中任意位置. ...
- 10.1综合强化刷题 Day5
T1 拼不出的数 lost.in/.out/.cpp[问题描述]3 个元素的集合{5; 1; 2}的所有子集的和分别是0; 1; 2; 3; 5; 6; 7; 8.发现最小的不能由该集合子集拼出的数字 ...
- 10.1综合强化刷题 Day4
财富(treasure) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK有n个小伙伴.每个小伙伴有一个身高hi. 这个游戏是这样的,LYK生活的环境是以 ...
随机推荐
- Windows下如何用CMD命令跳转到指定的目录下
以Window7为例说明,想要跳转到I:\adt-bundle-windows-x86-20130219\sdk\platform-tools目录下. 1.在运行中打开CMD命令窗口如下图所示: 2. ...
- Python中__str__和__repr__的区别
Python有一个内置的函数叫repr,它能把一个对象用字符串的形式表达出来以便辨认,这就是“字符串表示形式”.repr就是通过__repr__这个特殊方法来得到一个对象的字符串表示形式.如果没有实现 ...
- sqoop安装和使用
下载版本:sqoop-1.4.6.bin__hadoop-2.0.4-alpha.tar.gz 官网:http://mirror.bit.edu.cn/apache/sqoop/1.4.6/ jdbc ...
- IOS开发---菜鸟学习之路--(一)
PS(废话): 看了那么多的博客文章,发现大部分人都一直在强调写技术博客的重要性,索性自己也耐着性子写写看吧. 写博客的重要性之类的说明,我就不做复制黏贴的工作了.因为自己没有写过多少,所也不清楚是不 ...
- 【原创】React实例入门教程(1)基础API,JSX语法--hello world
前 言 毫无疑问,react是目前最最热门的框架(没有之一),了解并学习使用React,可以说是现在每个前端工程师都需要的. 在前端领域,一个框架为何会如此之火爆,无外乎两个原因:性能优秀,开发效率 ...
- linux环境搭建系列之svn安装
前提: linux centOS 64位操作系统 1.root账号 2.#yum install -y subversion 出现如下报错: 尝试Telnet https://www.baidu.co ...
- python 学习分享-函数篇
函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可以自己创建函数,这 ...
- Leetcode 532.数组中的K-diff数对
数组中的K-diff数对 给定一个整数数组和一个整数 k, 你需要在数组里找到不同的 k-diff 数对.这里将 k-diff 数对定义为一个整数对 (i, j), 其中 i 和 j 都是数组中的数字 ...
- 用例UML图
用例图主要用来描述“用户.需求.系统功能单元”之间的关系.它展示了一个外部用户能够观察到的系统功能模型图. [用途]:帮助开发团队以一种可视化的方式理解系统的功能需求. 用例图中涉及的关系有:关联.泛 ...
- 目标检测算法SSD在window环境下GPU配置训练自己的数据集
由于最近想试一下牛掰的目标检测算法SSD.于是乎,自己做了几千张数据(实际只有几百张,利用数据扩充算法比如镜像,噪声,切割,旋转等扩充到了几千张,其实还是很不够).于是在网上找了相关的介绍,自己处理数 ...