loli的搜索测试-我真不知道是第多少次了
搜索测试
又到了....并不激动人心的搜索测试时间。
今天和以前还是有一点不一样的,新高二的学长们也参加了(也就是说我们又要被吊打了)
话不多说,看题:
fz:填一个5*5的质数方阵,要求每行,每列,两个对角线上的数从左往右连起来都是质数,且每个质数都没有前导零,且每个质数的每位相加之和是一个给定的数,且左上角的数字给定,输出左右方案,没有就输出NONE。
是一个看起来非常可做,实际上非常不可做的题目,我写了1.5h之后样例竟然还要跑15s,是的你没有看错,就是十五秒,于是我弃疗了。我的思路是,首先制作一个合法的质数表,搜出第一行,再根据第一行(也就是每一列已经有了第一个数)来搜出五个竖列,第一行和第一列的数字都不能带0,之后每搜一个就判一判合法性。听起来已经挺优化的了,然而光荣爆零。最高分也只有40分,还是一个高二的学长写的。std是一个5kb的pascal文件,完全没有去读他的欲望,于是这个题就先咕咕咕了,贴一份我的0分代码吧。
# include <cstdio>
# include <iostream>
# define R register int using namespace std; const int maxn=;
bool pri[];
int ans=,cnt,s,beg,firs,t[],P[maxn]; int div (int x)
{
int S=;
while (x)
{
S+=x%;
x/=;
}
return S;
} int sw (int x,int i)
{
if(i==) return x/;
if(i==) return x/%;
if(i==) return x/%;
if(i==) return x/%;
return x%;
} void print()
{
for (R i=;i<=;++i)
{
for (R j=;j<=;++j)
printf("%d",sw(t[j],i));
printf("\n");
}
printf("\n");
} bool check()
{
int a=;
for (R i=;i<=;++i)
{
a=;
for (R j=;j<=;++j)
a=a*+sw(t[j],i);
if(pri[a]==false) return false;
}
a=;
for (R i=;i<=;++i)
a=a*+sw(t[i],i);
if(pri[a]==false) return false;
a=;
for (R i=;i<=;++i)
a=a*+sw(t[i],-i+);
if(pri[a]==false) return false;
return true;
} void dfs (int x)
{
int a,f;
if(x==)
{
if(check()) ans++,print();
return ;
}
if(x==)
{
for (R i=;i<=cnt;++i)
{
if(P[i]/!=sw(P[i],x)) continue;
if(sw(P[i],)==||sw(P[i],)==||sw(P[i],)==||sw(P[i],)==||sw(P[i],)==) continue;
t[]=P[i];
dfs();
}
}
else
{
for (R i=;i<=cnt;++i)
{
if(P[i]/!=sw(firs,x)) continue;
t[x]=P[i];
f=;
for (R j=;j<=;++j)
{
a=;
for (R k=;k<=x;++k)
a+=sw(t[k],j);
if(a>s) f=;
}
if(f) continue;
dfs(x+);
}
}
} int main()
{
freopen("fz.in","r",stdin);
freopen("fz.out","w",stdout); scanf("%d%d",&s,&beg);
for (R i=;i<=maxn;++i)
{
if(pri[i]) continue;
for (R j=;j*i<=maxn;++j)
pri[i*j]=true;
}
for (R i=;i<=;++i)
pri[i]=false;
for (R i=;i<=;++i)
{
pri[i]^=;
if(pri[i]&&div(i)!=s) pri[i]=false;
}
for (R i=;i<=;++i)
if(pri[i]) P[++cnt]=i;
for (R i=;i<=cnt;++i)
{
if(P[i]/!=beg) continue;
if(sw(P[i],)==||sw(P[i],)==||sw(P[i],)==||sw(P[i],)==||sw(P[i],)==) continue;
firs=P[i];
dfs();
}
if(ans==) printf("NONE");
fclose(stdin);
fclose(stdout);
return ;
}
fz
gift:很像背包,但是数据范围极大只能搜索的背包题,似乎要用$meet$ $in$ $the$ $middle$来做,但是爆搜可以得到$70$.
square:poj上一个挺经典的题目,就是问一些火柴棍删掉多少条才能破坏所有的正方形。不知道为什么大家都没有写这个题,咕咕咕?
loli的搜索测试-我真不知道是第多少次了的更多相关文章
- loli的搜索测试-4
其实这已经是第四次搜索测试了...只不过上两次测试时我不在学校,扔两个链接吧: 测试-2:https://www.luogu.org/blog/user35178/loli-di-sou-suo-ce ...
- loli的搜索测试-5
今天早上听说不放假感觉很sad,又听说要考试感觉更sad了,早读的时候Juan_feng表示即使考也不会考虫食算,结果上午并没有考试,就自己做了几道题.不得不说做题的决定实在是太明智了,做NOIP历年 ...
- web功能测试之表单、搜索测试
初入职场接触功能测试老是碰到以下情况不知道怎么写测试用例: 一个界面很多搜索条件怎么写用例?下拉框测试如何考虑测试点?上传要考虑哪些验证点?...... 所以这篇主要是整理关于web测试之表单.搜索测 ...
- 【测试工具】这些APP实用测试工具,不知道你就out了!
本期,我将给大家介绍14款实用的测试工具,希望能够帮到大家!(建议收藏) UI自动化测试工具 1. uiautomator2 Github地址:https://github.com/openatx/u ...
- xamarin.forms uwp app部署到手机移动设备进行测试,真机调试(device portal方式部署)
最近学习xamarin.刚好 手上有一个lumia 930.所以试一试把uwp app部署到手机上,并真机调试一把. 目前环境: 1.开发pc电脑是win10,版本1607.加入了insider,所以 ...
- elasticsearch http 搜索 测试
1.查询所有的documents http://192.168.43.45:9200/_search boost parameter 细粒度搜索条件权重控制 如:组装多个查询条件,其中一个匹配的想要优 ...
- xunsearch搜索测试
1.导入测试数据 cd $prefix/sdk/php util/Indexer.php --source=csv --clean demo 然后出现 初始化数据源 ... csv WARNING: ...
- Web测试转App测试不看不知道
Web测试 Web通常指的是互联网应用系统,比如税务电子化征管档案系统.金融数据平台.餐饮商家管理后台等等,其实质是C/S的程序. C是Client--客户端,S是Server--服务器. Web中的 ...
- 真不知道JavaScrip【数组】还有这么多东西....
前段时间在频繁的用数组,但一直不知道JavaScript 数组还有这么多东西,收集了一下看看: 首先:数组是对象的特殊形式,接下来看看它有哪些方法.....push()在末尾增加一个或者是多个 uns ...
随机推荐
- 使用pl/sql的文本导入器时如何设置主键自增长
在使用文本导入器批量导入数据时,如果需要设置主键自增长,可以先创建一个序列: create sequence SEQ_Userinf start with 1 increment by 1nomaxv ...
- Android瀑布流照片
http://blog.csdn.net/guolin_blog/article/details/10470797 记得我在之前已经写过一篇关于如何在Android上实现照片墙功能的文章了,但那个时候 ...
- 在Oracle中实现每日表备份并删除7天前的备份表
不用闪回技术,因为业务想眼睁睁的看到备份表,而不是让DBA搞一通之后,才能看到备份数据表 OK,那好办了,写个存储过程解决你的需求,每天建个新表,把数据备份进去,业务人员可以看到这些每天的备份表 然后 ...
- Codeforces292D(SummerTrainingDay06-L 前缀并查集)
D. Connected Components time limit per test:2 seconds memory limit per test:256 megabytes input:stan ...
- BZOJ4373: 算术天才⑨与等差数列(线段树 hash?)
题意 题目链接 Sol 正经做法不会,听lxl讲了一种很神奇的方法 我们考虑如果满足条件,那么需要具备什么条件 设mx为询问区间最大值,mn为询问区间最小值 mx - mn = (r - l) * k ...
- 图片轮播(Jquery)
昨天在博客园里面看到imwtr写的图片轮播(淡入淡出)的文章,觉得是否自己可以将该功能写成Jquery插件的形式,也方便之后如果需要的时候可以直接使用. 经过调整和整合,完成了第一版本的jquery. ...
- Javascript、Jquery获取浏览器和屏幕各种高度宽度[mark]
Javascript: IE中:document.body.clientWidth ==> BODY对象宽度document.body.clientHeight ==> BODY对象高度d ...
- Nginx的常用功能
1.规范nginx的配置文件 在企业中我们的虚拟主机可能会很多,配置文件的内容也会有很多,这时候我们就可以规范一下我们的配置文件,把每个虚拟主机按照网站的域名或者是功能取名,放到统一的文件夹中,当然我 ...
- React Native常用第三方组件汇总--史上最全 之一
React Native 项目常用第三方组件汇总: react-native-animatable 动画 react-native-carousel 轮播 react-native-countdown ...
- Mongodb的入门(4)mongodb3.6的索引
Mongodb的索引: 在介绍索引之前,再强调一下nosql数据库和sql数据库的区别: sql数据库:结构化数据,定好了表格后,每一行的内容都是结构化的 mongo:文档数据,表下的数据都可以有自己 ...