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 ...
随机推荐
- MVC初级知识之——View与Controller的讲解
Controller是MVC中比较重要的一部分.几乎所有的业务逻辑都是在这里进行处理的,并且从Model中取出数据.在ASP.NET MVC Preview5中,将原来的Controller类一分为二 ...
- Android studio删除工程项目
本新手最近学Android都是用的eclipse.其实个人觉得eclipse不错,可能接触Android不久,倒也不觉得它慢还是怎样.对于Google的Android studio也是早有耳闻,前两天 ...
- 用Collectors对List去重
在学习本篇之前,最好对java8新特性有一定的了解.可以参考:Java8新特性--流(Stream) 场景:有一个实体的List集合,需要根据实体中的某个字段对List去重 要想去重,可以考虑使用Tr ...
- JWT操作(.net)
1.JWT定义 JWT(Json Web Token)是一种用于双方之间传递安全信息的简洁的.URL安全的表述性声明规范.JWT作为一个开放的标准( RFC 7519 ),定义了一种简洁的,自包含的方 ...
- 【转】Java工程师成神之路
针对本文,博主最近在写<成神之路系列文章> ,分章分节介绍所有知识点.欢迎关注. 一.基础篇 1.1 JVM 1.1.1. Java内存模型,Java内存管理,Java堆和栈,垃圾回收 h ...
- elasticsearch6.7 05. Document APIs(2)Index API
Single document APIs Index API Get API Delete API Update API Multi-document APIs Multi Get API Bulk ...
- MySQL,Oracle建立主键自增表
MySQL 在建表的时候声明字段即可 id int auto_increment primary key not null Oracle 第一步:建立表 drop table t_role; crea ...
- ERP、CRM、CMS
ERP: 全称:Enterprise Resource Planning 解释:企业资源计划. ERP 是一种主要面向制造行业进行物质资源.资金资源和信息资源集成一体化管理的企业信息管理系统.ERP ...
- Python os、sys、pickle、json等模块
1.os 所有和操作系统相关的内容都在os模块,一般用来操作文件系统 import os os.makedirs('dirname1/dirname2') # 可生成多层递归目录 os.removed ...
- 【代码笔记】iOS-自定义loading(IanAlert)
一,效果图. 二,工程图. 三,代码. ViewController.h #import <UIKit/UIKit.h> @interface ViewController : UIVie ...