2018年奇虎360春招笔试题--玫瑰花
这道题,第一感觉想用排列组合做,但是想了好久,没想到解决办法(刚刚考试的时候没有答出来)。后来想了一下应该使用动态规划来做。
我们首先分析一下情况:
1.当K>N的时候,countSum = 0;
2.当K=N的时候,countSum = N!(N的阶乘)
3.当K>N的时候,就要通过最优子结构来进行分析了。
前两点易知,下面主要分析第三点。
设F(k,n)为n个位置,k种玫瑰的结果,则 F(k,n) = k*(F(k,n-1)+F(k-1,n-1)),分析:
情况一:n-1个空缺已经放置了k种花,则新的位置放置任何一种花都可以,此时结果总数为k*F(k,n-1);
情况二:n-1个空缺已经放置了k-1种花(注意!有k种选择!),则新的位置固定需要放置剩下的那一种花,此时结果总数为k*F(k-1,n-1);
总数 = 情况一 + 情况二
代码如下:
public class Rose { public static void main(String[] args){ System.out.println(roseSum(2,3)); } public static long roseSum(int k,int n){ if(k>n) return 0; if(k == n){ int count = 1; for(int i = 0;i<n;i++) count*=i; return count; } long[][] DP = new long[k][n]; for(int i = 0 ;i<n;i++) DP[0][i] = 1; for(int i = 1;i<k;i++) DP[i][0] = 0; for(int i = 1;i<k;i++) for(int j = 1;j<n;j++) DP[i][j] = (i+1)*(DP[i][j-1]+DP[i-1][j-1]); return DP[k-1][n-1]%772235; } }
不过此代码虽然是使用动态规划解决,但是空间复杂度为O(N*K),并不是最优,还可继续优化。
优化代码如下:
public class Rose { public static void main(String[] args){ System.out.println(roseSum(2,3)); } public static long roseSum(int k,int n){ if(k > n) return 0; if(k == n){ int count = 1; for(int i = 0;i<n;i++) count*=i; return count; } long[][] DP = new long[2][n]; for(int i = 0 ;i<n;i++) DP[0][i] = 1; DP[1][0] = 0; for(int i = 1;i<k;i++) for(int j = 1;j<n;j++) if((i&1)==1){//此时i是奇数 DP[1][j] = (i+1)*(DP[1][j-1]+DP[0][j-1]); }else{ DP[0][j] = (i+1)*(DP[0][j-1]+DP[1][j-1]); } return DP[(k-1)&1][n-1]%772235; } }
这回的空间复杂度为O(N)。
自己想出来的,不一定准确,没经过大量试验,如有错误,请各位朋友指出,谢谢~
作者:郭耀华
出处:http://www.guoyaohua.com
微信:guoyaohua167
邮箱:guo.yaohua@foxmail.com
本文版权归作者和博客园所有,欢迎转载,转载请标明出处。
【如果你觉得本文还不错,对你的学习带来了些许帮助,请帮忙点击右下角的推荐】
出处:http://www.guoyaohua.com
微信:guoyaohua167
邮箱:guo.yaohua@foxmail.com
本文版权归作者和博客园所有,欢迎转载,转载请标明出处。
【如果你觉得本文还不错,对你的学习带来了些许帮助,请帮忙点击右下角的推荐】

分类:
剑指offer刷题
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?