LG1036
当我们看到这道题的时候,我们不仅大吼一声,这不就是搜索嘛。
于是搜索两大刀!搜索目标和搜索状态!
搜索目标:求选数的方案,以及他们的和是否为质数。
搜索状态:
1.从后往前分析目标(或从前往后):和是否为质数,很明显我们可以设计一个参数代表当前选数的和i,至于是否为质数的特判肯定就放到了函数里面了。但是你要注意和要为质数是在题目中对应的几个数相加才可以的来的,所以我们要设计一个参数来确定你选了几个数j,其实和,这个和是对应的。至于选数的方案,其实我们并不在意咋选的,我们需要一个参数能够,明确彰显搜索的每一步状态的,所以说我之前写过状态的设计需要,明确搜索步骤,或者说,准确得描述搜索步骤。当然根据我的感觉,一般用序数的东西比较好。比如这里人家设计的是k,代表你遍历到了第几个数。
综上,状态为(i,j,k),i代表你遍历到了第几个数;j代表你之前选的数的和;k代表你之前选了几个数。
但是人家的dfs中还有两部分,一部分是边界性问题,比如题目中给你4个数让你选,而你都选到了5个数,那显然不可能,那可能嘛》所以你这个时候就得return .
另一个部分是,设计下一步问题,其实这个感觉也是因题意而变。
分成(x+1,y,z)和
(x+1,y+a[x],z+1),这个就是两步,你遍历必须要经历的步骤,要么选,要么不选。
至于我觉得对我来说比较大的问题就是,关于这个质数的筛选,
我之前是这样写的
int isprime(int x)
{
if(x==) return -;
if(x==) return ;
int k=x;
int j=pow(k,/)+;
for(int i=;i<=j;i++) {
if(k%i==) return -;
} return ; }
但是只过了一半的点,然后根据下载的错误数据,我发现了问题在于质数的筛选上,于是我换了一个筛选质数的方法
int isprime(int x)
{
~~~
int k=x;
//大部分跟上一个一样
for(int i=2;i<=k;i++)
{
if(k%i==0) return -1; }
return 1 }
简单说我就是全枚举了一遍,然而上一个测试数据过了,但是还有几个都没过!比之前第一次过的还少!
没办法,看了别人的题解,发现了一种新的质数筛选的方法
int isprime(int x)
{ //其他都差不多,关键在于循环判断的条件上)
for(int i=;i*i<=x;i++)
****
}
然后这个就全过了。。。我也是。。。
不是很理解。
在我敲代码的时候,我必须得说,你没有考虑数据范围这个问题,因为人家之前给你提示了,
所以在思考题的时候一定要思考问题,防止报数据!
又出现了全局变量的问题。。。思考不全面,重新打一遍,
所以说最靠谱的是先在脑子里一遍过好。。
同时又出现了函数先后调用,定义函数顺序的问题。
所以再敲一遍给我的启示是,
1,考虑数据范围
2,考虑函数定义的先后顺序。
3,写代码前把东西都想好。
4,再敲一遍,一遍过。
5,至少这里要多定义全局变量。
6,注意每写一个模块,都要检查一下。
最后写完的时候,再检查所有。
LG1036的更多相关文章
随机推荐
- Delphi 开发微信公众平台 (三)- 获取微信服务器IP地址
如果公众号基于安全等考虑,需要获知微信服务器的IP地址列表,以便进行相关限制,可以通过该接口获得微信服务器IP地址列表或者IP网段信息. 接口调用请求说明 http 请求方式: GET https:/ ...
- Python使用队列实现Josephus问题
Josephus问题,在这个古老的问题中,N个深陷绝境的人一致同意通过以下方式减少生存的人数.他们围坐一圈(位置记为0~N-1)并从第一个人报数,报到M的人会被杀死, 知道最后一个人留下来.传说中Jo ...
- python笔记:删除列表元素和根据索引查找元素
查找元素 #查找元素 >>> member=['张三','李四','王五','张麻子'] >>> member[0] '张三' #交换元素 >>> ...
- TCP协议学习笔记
TCP协议数据格式 TCP协议在互联网ISO协议的传输层. 在互联网传输过程中,互联网包在数据链路层,是传输数据的最基础的包.一个互联网的包包含IP包,即互联网包 = 互联网信息包头(至少20字节)+ ...
- Java核心技术梳理-类加载机制与反射
一.引言 反射机制是一个非常好用的机制,C#和Java中都有反射,反射机制简单来说就是在程序运行状态时,对于任意一个类,能够知道这个类的所有属性和方法,对于任意一个对象,能够调用它的任意属性和方法,其 ...
- 阿里巴巴 Java 开发手册(三): 代码格式
1. [强制]大括号的使用约定.如果是大括号内为空,则简洁地写成{}即可,不需要换行:如果 是非空代码块则: 1) 左大括号前不换行. 2) 左大括号后换行. 3) 右大括号前换行. 4) 右大括号后 ...
- C# 调用 C++ dll的两种方式
目录: 1.非托管方式 2.托管方式 3.介绍 extern "C" 4.介绍 DllImport 1.非托管方式 第一种,非托管方式:调用类和方法https://www.co ...
- 强大的Grafana k8s 插件
原文参考: https://i4t.com/4152.html 参考:https://blog.csdn.net/mailjoin/article/details/81389700 插件链接:http ...
- kafka汇总
Kafka 1. kafka概念 kafka是一个高吞吐亮的.分布式.基于发布/订阅(也就是一对多)的消息系统,最初由Linkedln公司开发的,使用Scala语言编写的,目前是Apache的开源项目 ...
- vue项目中添加单元测试
从网上找了很多例子关于单元测试,都是如何新建项目的时候的添加单元测试,用vue-cli中怎么添加,但是我的项目已经生成了,不能再一次重新初始化,这时如何添加单元测试,这里面遇到了好多坑,写在这里记录一 ...