NOIP2017SummerTraining0726
三道比较简单的题,还以为是八校考试的题目,但是并不是,无语了,第三题其实看了挺久的,一看到图,就想到了二分图,网络流之类的算法,但是尽力往这个方向想了好久都没什么思路,
最后从简单入手,然而没什么结果,第一题是真的水,一推就知道了。
谜题
时间限制: 1 Sec 内存限制: 128 MB
提交: 90 解决: 47
[提交][状态][讨论版]
题目描述
输入
输出
样例输入
样例输出
提示
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<iostream>
using namespace std;
int n;
int main()
{
scanf("%d",&n);
) printf("YES\n");
else printf("XLSB\n");
}
题意什么的不要了
选修课
时间限制: 1 Sec 内存限制: 128 MB
提交: 172 解决: 61
[提交][状态][讨论版]
题目描述
输入
输出
样例输入
1
2
样例输出
提示
#include<cstring>
#include<algorithm>
#include<iostream>
#include<cmath>
#include<cstdio>
using namespace std;
int n;
]={};
];
bool cmp(int x,int y){return x>y;}
long long C(int m,int n)
{
;
;i<=m;i++)
res=(long long)(res*i);
;i<=n;i++)
res=(long long)(res/i);
return res;
}
int main()
{
scanf("%s%d",s,&n);
int len=strlen(s);
;i<len;i++)
a[s[i]-]++;
sort(a+,a++,cmp);
;
;i<=n;i++)
res+=a[i];
printf("%lld ",res);
int l=n,r=n;
&&a[l]==a[n]) l--;
l++;
&&a[r]==a[n]) r++;
r--;
long long ans;
ans=C(r-l+,min(n-l+,r-n));
printf("%lld\n",ans);
}
满分代码
质数
时间限制: 1 Sec 内存限制: 128 MB
提交: 106 解决: 20
[提交][状态][讨论版]
题目描述
宿管有一套神奇的控制系统来控制寝室的灯的开关:

输入
输出
样例输入
10 2
2 5
21 4
2 3 5 7
100 1
5
100 3
3 19 7
样例输出
11
20
42
提示
这道题就是求√n以内的质数,这样比√n大的质数两两之间已经超过了n因此不会相互影响,可以发信啊每个开关只开一次是有意义的,多开没意义。
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
,NN=;
int n,m,ans,k;
int boo[NN],prime[NN];
bool cmp(int x,int y){return x<y;}
void dfs(int ci)
{
if (ci==k)
{
,num;
queue<int>q;
while(!q.empty()) q.pop();
;i<=m;i++)
{
num=;
for (int j=prime[i];j<=n;j+=prime[i])
) num++;
else num--;
)
{
q.push(i);
for (int j=prime[i];j<=n;j+=prime[i])
boo[j]^=;
}
}
;i<=n;i++)
if (boo[i]) x++;
ans=max(ans,x);
while (!q.empty())
{
int i=q.front();
q.pop();
for (int j=prime[i];j<=n;j+=prime[i])
boo[j]^=;
}
}
else
{
ci++;
dfs(ci);
for (int i=prime[ci];i<=n;i+=prime[ci])
boo[i]^=;
dfs(ci);
for (int i=prime[ci];i<=n;i+=prime[ci])
boo[i]^=;
}
}
void solve()
{
ans=-INF;
memset(boo,,sizeof(boo));
dfs();
printf("%d\n",ans);
}
int main()
{
int Cas;
scanf("%d",&Cas);
while (Cas--)
{
scanf("%d%d",&n,&m);
;i<=m;i++)
scanf("%d",&prime[i]);
sort(prime+,prime+m+,cmp);
k=m;
while (prime[k]>(int)sqrt(n)) k--;
solve();
}
}
NOIP2017SummerTraining0726的更多相关文章
随机推荐
- Java内存模型_基础
线程之间的通信机制有两种: 1.共享内存:线程之间共享程序的公共状态,通过写-读内存中的公共状态进行隐式的通信. 2.消息传递:线程之间没有公共状态,线程之间必须发送消息来显示的进行通信 同步:是指程 ...
- 各种选择框jQuery的选中方法
select下拉列表的选中方法是:$("slect option:eq(1)").attr("selected",true);//选中第二个option che ...
- CyclicBarrier和CountDownLatch介绍
详见: http://blog.yemou.net/article/query/info/tytfjhfascvhzxcytp70 CyclicBarrier介绍 (一) 一个同步辅助类,它允许一组线 ...
- Day-8: 面对对象编程
面对过程的程序设计方法意在将函数分成子函数,再依次调用这些函数来解决问题. 而面对对象的程序设计方法,来源于自然界,类是实例的抽象,实例是类的具体.自定义出来的对象是类,而所有的数据都可以看成是对象, ...
- Java基础学习 —— bat处理文件
bat处理文件:就是一次性可以执行多个命令的文件 为什么要学bat处理文件? 快速运行一个软件我一般都会打包成jar包的形式来执行jar双击对图形界面管用 但是对控制台的程序是不起作用的.对于控制台的 ...
- Django1.10主题指南—模型
模型是你的数据的唯一的.权威的信息源.它包含你所储存数据的必要字段和操作行为.通常,每个模型都对应着数据库中的唯一一张表. 基础认识: 每个model都是一个继承 django.db.models.M ...
- sqlserver与mysql中vachar(n)中遇到的坑
前两天在做将mysql的数据表导入到sqlserver当中. 本人比较愚笨,操作方法 是先将mysql的数据表到处为insert脚本,再在sqlserver中执行sql脚本 在网上看了一下那些方法 , ...
- PHP(函数)
<script> // 获得日 var time = new Date(); var x = time.getDate(); document.write(x+"日," ...
- 201521123024 《Java程序设计》第6周学习总结
1. 本周学习总结 2. 书面作业 1.clone方法 1.1 Object对象中的clone方法是被protected修饰,在自定义的类中覆盖clone方法时需要注意什么? 用protected修饰 ...
- 201521123038 《Java程序设计》 第三周学习总结
201521123038 <Java程序设计> 第三周学习总结 1. 本周学习总结 附大图链接 http://naotu.baidu.com/file/5774caa2be710afbc0 ...