搜索测试

  又到了....并不激动人心的搜索测试时间。

  今天和以前还是有一点不一样的,新高二的学长们也参加了(也就是说我们又要被吊打了)

  话不多说,看题:

  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的搜索测试-我真不知道是第多少次了的更多相关文章

  1. loli的搜索测试-4

    其实这已经是第四次搜索测试了...只不过上两次测试时我不在学校,扔两个链接吧: 测试-2:https://www.luogu.org/blog/user35178/loli-di-sou-suo-ce ...

  2. loli的搜索测试-5

    今天早上听说不放假感觉很sad,又听说要考试感觉更sad了,早读的时候Juan_feng表示即使考也不会考虫食算,结果上午并没有考试,就自己做了几道题.不得不说做题的决定实在是太明智了,做NOIP历年 ...

  3. web功能测试之表单、搜索测试

    初入职场接触功能测试老是碰到以下情况不知道怎么写测试用例: 一个界面很多搜索条件怎么写用例?下拉框测试如何考虑测试点?上传要考虑哪些验证点?...... 所以这篇主要是整理关于web测试之表单.搜索测 ...

  4. 【测试工具】这些APP实用测试工具,不知道你就out了!

    本期,我将给大家介绍14款实用的测试工具,希望能够帮到大家!(建议收藏) UI自动化测试工具 1. uiautomator2 Github地址:https://github.com/openatx/u ...

  5. xamarin.forms uwp app部署到手机移动设备进行测试,真机调试(device portal方式部署)

    最近学习xamarin.刚好 手上有一个lumia 930.所以试一试把uwp app部署到手机上,并真机调试一把. 目前环境: 1.开发pc电脑是win10,版本1607.加入了insider,所以 ...

  6. elasticsearch http 搜索 测试

    1.查询所有的documents http://192.168.43.45:9200/_search boost parameter 细粒度搜索条件权重控制 如:组装多个查询条件,其中一个匹配的想要优 ...

  7. xunsearch搜索测试

    1.导入测试数据 cd $prefix/sdk/php util/Indexer.php --source=csv --clean demo 然后出现 初始化数据源 ... csv WARNING: ...

  8. Web测试转App测试不看不知道

    Web测试 Web通常指的是互联网应用系统,比如税务电子化征管档案系统.金融数据平台.餐饮商家管理后台等等,其实质是C/S的程序. C是Client--客户端,S是Server--服务器. Web中的 ...

  9. 真不知道JavaScrip【数组】还有这么多东西....

    前段时间在频繁的用数组,但一直不知道JavaScript 数组还有这么多东西,收集了一下看看: 首先:数组是对象的特殊形式,接下来看看它有哪些方法.....push()在末尾增加一个或者是多个 uns ...

随机推荐

  1. Spring基础(6) : 普通Bean对象中保存ApplicationContext

    public class Person implements ApplicationContextAware{ ApplicationContext context; public String na ...

  2. [android] ndk环境的搭建

    C语言的编辑加运行,分两步 编译阶段 连接阶段 java语言的步骤是 转成.class文件  java的虚拟机运行 C语言在windows上==> .o中间文件 ==>.exe可执行文件 ...

  3. arm裸板驱动总结(makefile+lds链接脚本+裸板调试)

    在裸板2440中,当我们使用nand启动时,2440会自动将前4k字节复制到内部sram中,如下图所示: 然而此时的SDRAM.nandflash的控制时序等都还没初始化,所以我们就只能使用前0~40 ...

  4. Java中类的线程安全问题

    java中各种集合(字符串类)的线程安全性!!! 一.概念: 线程安全:就是当多线程访问时,采用了加锁的机制:即当一个线程访问该类的某个数据时,会对这个数据进行保护,其他线程不能对其访问,直到该线程读 ...

  5. 应用rbac组件 动态生成一级菜单

    动态生成一级菜单 改表结构 需要知道是否是菜单\icon\名称权限表 +字段: is_menu = models.BooleanField(max_length=32,verbose_name='是否 ...

  6. django-缓存的应用

    为什么需要缓存? django中文文档: 通常,计算值是昂贵的(即资源匮乏和缓慢),因此将值保存到可快速访问的缓存中可以有巨大的好处,为下一次需要做好准备. 这是一个足够重要和强大的技术,Django ...

  7. KOTLIN-1(常用网址)

    ---恢复内容开始--- 1.官网:http://kotlinlang.org/ 2.官方文档:https://kotlinlang.org/docs/reference 3.kotlin源码:htt ...

  8. 分享一个 jsPDF的简单使用以及中文编码问题的解决

    后台一个下载文件中内容国际化问题的坑甩到了前端 前端自己匹配,自己处理国际化,生成文件下载 jsPDF-AutoTable    挺靠谱 中文乱码, 还是好人多啊 解决方式如下文章 jsPDF的简单使 ...

  9. ie8 透明背景不能点击问题

    最近开发网站,需求是三个一屏,1和3只能看见一半,2显示在中间,无箭头按钮. 因为之前写过一个有前后按钮的插件,想着怎么就在这上面改造,故把前后按钮去掉背景,定位在了1和3的位置上来实现点击前后, 发 ...

  10. go语言练习:接口

    package main import ( "fmt" ) type Run interface { //这个接口的名字命名成Car更直观一点,除了distance方法外,后面可以 ...