题目链接:Captain Flint and Crew Recruitment

题意:

t组输入,每一组输入一个n。这里我们说一下题目定义的近似质数概念:

“如果可以将正整数x表示为p⋅q,则将其定义为近似质数,其中1 <p <q,p和q是质数。 例如,整数6和10几乎是质数(因为2⋅3= 6和2⋅5= 10),但整数1、3、4、16、17不是。”

这里我们把n分成四个数的和,你需要使这四个数中的至少三个数都是近似质数,且要保证这四个数互不相等

如果能找出来这四个数就输出,否则输出NO

题解:

因为只需要三个数都是近似质数就行,那么最小的三个近似质数是6,10,14那么n的大小最小要等于31才可以有解

这里要注意,题目要求四个数要互不相等,那么我们就需要特判一下36,40,44

代码:

 1 #include<stack>
2 #include<queue>
3 #include<map>
4 #include<cstdio>
5 #include<cstring>
6 #include<iostream>
7 #include<algorithm>
8 #define fi first
9 #define se second
10 using namespace std;
11 typedef long long ll;
12 const int maxn=1e5+10;
13 const int mod=1e9+7;
14 const double eps=1e-8;
15 int a[maxn],b[maxn];
16 int main()
17 {
18 int t;
19 scanf("%d",&t);
20 while(t--)
21 {
22 int n;
23 scanf("%d",&n);
24 if(n==36)
25 {
26 printf("YES\n");
27 printf("5 6 10 15\n");
28 }
29 else if(n==40)
30 {
31 printf("YES\n");
32 printf("15 6 10 9\n");
33 }
34 else if(n==44)
35 {
36 printf("YES\n");
37 printf("6 7 10 21\n");
38 }
39 else if(n>6+10+14)
40 {
41 printf("YES\n");
42 printf("6 10 14 ");
43 printf("%d\n",n-30);
44 }
45 else
46 {
47 printf("NO\n");
48 }
49 }
50 return 0;
51 }

题目链接:Captain Flint and a Long Voyage

题意:

t组输入,每组数据给你一个n,代表数x的长度,这个x是你需要找到的一个整数。你把x的每一位数转化成二进制形式后就是k

例如 x=729, 那么 k=111101001 (因为 7=111, 2=10, 9=1001).

然后你把k的末尾n个二进制数删除,就是最后的结果,例如上面的例子删除之后就变成了111101

你要使这个结果尽可能的大,所以给你一个n,让你求能使最后结果尽可能大的最小的那个x是多少,然后输出x

题解:

你会发现整数8、9转化成二进制都是4位,所以我们的x肯定是由8、9构成的,那么什么时候用8什么时候用9呢?

比较来看8、9的二进制形式也就只有最后一位不同

题目又说输出那个最小的x,题目的x转化成k之后,还要删除末尾的n个二进制数。删除这n个二进制数由8这个整数构成才可以使得x最小

所以x的最后n/4+(n%4!=0)位输出8,剩下的输出9

代码:

 1 #include<stack>
2 #include<queue>
3 #include<map>
4 #include<cstdio>
5 #include<cstring>
6 #include<iostream>
7 #include<algorithm>
8 #define fi first
9 #define se second
10 using namespace std;
11 typedef long long ll;
12 const int maxn=1e5+10;
13 const int mod=1e9+7;
14 const double eps=1e-8;
15 int a[maxn],b[maxn];
16 int main()
17 {
18 int t;
19 scanf("%d",&t);
20 while(t--)
21 {
22 int n;
23 scanf("%d",&n);
24 int ans=n/4;
25 if(n%4)
26 ans++;
27 for(int i=1;i<=n-ans;++i)
28 printf("9");
29 for(int i=1;i<ans;++i)
30 printf("8");
31 printf("8\n");
32 }
33 return 0;
34 }

最新文章

  1. Ajax传递路径问题及解决
  2. CentOS 7 安装 nginx
  3. HDU2546(01背包饭卡)
  4. Counting Bits
  5. 2.python基础深入(元组、字符串、列表、字典)
  6. Reverse Linked List II [LeetCode]
  7. bootstrap02导航菜单
  8. 详细介绍如何使用kindEditor编辑器
  9. Spring 3.x企业应用开发实战(11)----基于@AspectJ配置切面
  10. USACO maze1 BFS
  11. 如何使用开源库,吐在VS2013发布之前,顺便介绍下V2013的新特性&quot;Bootstrap&quot;
  12. makefile中&quot;:=&quot;,&quot;=&quot;,&quot;?=&quot;,&quot;+=&quot; 之间的区别
  13. [转载]ACM搜索算法总结(总结)
  14. CentOS 7下使用Gitolite搭建Git私服
  15. python request Payload 数据处理
  16. python 命令行颜色
  17. Android WebView 实现网页缩放
  18. ubuntu14.04 anaconda tensorflow spyder(python3.5) + opencv3
  19. springboot+mybatis+freemark+oauth开发环境搭建
  20. 使用eclipse自动生成WSDL客户端代码

热门文章

  1. 你必须要懂的 Github 开源协议
  2. Openstack Ocata 负载均衡安装(二)
  3. python函数1-函数基础
  4. 【Linux】如何查找命令及历史记录history
  5. 【Linux】记一次xfs分区数据恢复
  6. 5.2 Spring5源码--Spring AOP源码分析二
  7. C# datagridview设置标题为汉语
  8. SQL Server management studio使用sa连接时报错与伺服器的连接已成功,但在登入程序是发生错误
  9. ABAP program lines are wider than the internal table
  10. 解决PHP无法监听9000端口问题/502错误解决办法