A. Maximum GCD

题意:

t组输入,然后输入一个n,让你在区间[1,n]之间找出来两个不相等的数a,b。求出来gcd(a,b)(也就是a,b最大公约数)。让你求出来最大的gcd(a,b)是多少。

题解:

最大gcd(a,b),那就是n/2向下取整的结果。因为如果gcd(a,b)越大,那么a/gcd(a,b)或者b/gcd(a,b)的值肯定越小,最小也就是2了,所以输出n/2就行

代码:

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string>
5 #include<queue>
6 #include<string.h>
7 #include<map>
8 #include <iostream>
9 #include <math.h>
10 using namespace std;
11 typedef long long ll;
12 int main()
13 {
14 int t;
15 scanf("%d",&t);
16 while(t--)
17 {
18 int n;
19 scanf("%d",&n);
20 printf("%d\n",n/2);
21 }
22 return 0;
23 }

B. GCD Compression

题意:

t组输入,你首先有一个长度为2*n的数组,你需要压缩a数组长度为n-1。你可以扔掉a数组中的两个元素,将剩下的元素两两一组相加,它的值作为新数组b的一个值。你需要保证这个新数组b的gcd大于1(即,gcd(b1,b2...b(n-1) >1)

题解:

刚开始不知道怎么写,如果考虑所有因子那就不好弄了。但是题目上面说了,你只需要保证你构造的新数组b的公共最大公因子大于1就行,那么我们取他们的因子里面至少包含2这个因子。包含2这个因子的话,只要新数组的值都是偶数就可以满足题意(因为他们至少有一个公因子2,而这个2都大于1.所以肯定会满足题意)。那么我们就只要能构造一个都是偶数的新数组就行。偶数+偶数、奇数+奇数、就这样凑肯定可以。因为我们还可以丢弃两个元素,如果a数组的偶数个数为奇数就把扔掉一个,同样如果a数组的奇数个数为奇数就把扔掉一个。

代码:

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string>
5 #include<queue>
6 #include<string.h>
7 #include<map>
8 #include <iostream>
9 #include <math.h>
10 using namespace std;
11 typedef long long ll;
12 const int maxn=2e3+10;
13 int que1[maxn],que2[maxn],index1,index2;
14 int main()
15 {
16 int t;
17 scanf("%d",&t);
18 while(t--)
19 {
20 index1=index2=0;
21 int n;
22 scanf("%d",&n);
23 for(int i=1;i<=2*n;++i)
24 {
25 int x;
26 scanf("%d",&x);
27 if(x%2)
28 {
29 que1[index1++]=i;
30 }
31 else que2[index2++]=i;
32 }
33 for(int i=1;i<index1;)
34 {
35 if(n==1)
36 break;
37 printf("%d %d\n",que1[i-1],que1[i]);
38 n--;
39 i+=2;
40 }
41 for(int i=1;i<index2;)
42 {
43 if(n==1)
44 break;
45 printf("%d %d\n",que2[i-1],que2[i]);
46 n--;
47 i+=2;
48 }
49 }
50 return 0;
51 }

C. Number Game

题意:

对于一个n,你可以从下面两种操作中选一种执行

1、将n除于它的奇数因子(它的因子不包括1但是包括它本身)

2、将n减去1

上面两种操作的前提都是n大于1.

如果谁没有办法执行操作,那么谁就输了

第一步由Ashishgup先走

题解:

1、特判

n==1的时候对方必胜

n==2的时候Ashishgup必胜

2、如果n是一个奇数,那么Ashishgup必胜。因为n可以执行操作1除于n的因子n本身

3、如果n为偶数,且有奇数因子,我们一定可以把n拆为一个奇数和一个没有奇数因子(除1外)的偶数相乘,这样Ashishgup留给对手的就是一个没有奇数因子的偶数x,对手只能做减一操作,如果x不为2,那么Ashishgup就得到一个奇数,直接除以自身即可,此时Ashishgup必胜。否则就输了。

所以我们只需要找出来n的最大奇数因子,然后判断一下n除于这个最大奇数因子的值等不等于2就行

代码:

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string>
5 #include<queue>
6 #include<string.h>
7 #include<map>
8 #include <iostream>
9 #include <math.h>
10 using namespace std;
11 typedef long long ll;
12 const int maxn=2e3+10;
13 int result(int n)
14 {
15 int ans=0;
16 for(int i=2; i<=n/i; ++i)
17 {
18 if(n%i==0)
19 {
20 if(i%2 && n/i!=2)
21 ans=max(ans,i);
22 if((n/i)%2 && i!=2)
23 ans=max(ans,n/i);
24 // if(i!=2 && n/i!=2)
25 // {
26 // if(i%2==1 || (n/i)%2==1)
27 // {
28 // return true;
29 // }
30 // }
31 }
32 }
33 if(ans) return 1;
34 return 0;
35 }
36 int main()
37 {
38 int t;
39 scanf("%d",&t);
40 while(t--)
41 {
42 int n;
43 scanf("%d",&n);
44 if(n%2)
45 {
46 if(n==1)
47 {
48 printf("FastestFinger\n");
49 }
50 else printf("Ashishgup\n");
51 }
52 else
53 {
54 int ans=result(n);
55 //printf("%d***\n",ans);
56 if(n==2)
57 {
58 printf("Ashishgup\n");
59 }
60 else if(ans)
61 {
62 printf("Ashishgup\n");
63 }
64 else printf("FastestFinger\n");
65 }
66 }
67 return 0;
68 }

D. Odd-Even Subsequence

题意:

给你一个长度为n的数组v,你需要把它的长度缩减为k。缩减操作就是删除v数组中的某个位置的元素。注意元素下标从1开始,而且你只能删除某个位置的元素,并不能改变它们的顺序。我们设我们操作过后长度为k的数组为a,那么我们设这个数组所有奇数下标所对应的值中最大的那个值为x,我们设这个数组所有偶数下标所对应的值中最大的那个值为y,我们只需要输出min(x,y)就行。我们要尽量使输出的值尽量小

题解:

答案具有单调性,二分答案,然后看能不能满足有大于等于k个元素满足条件。因为我们最后输出的是min(x,y),所以只要偶数下标的满足那个答案,或者奇数下标的满足答案就行。

这里对偶数下标满足答案为例:

假设偶数下标所对应的值中最大的那个值小于等于答案,那么我们取第一个元素就直接取原数组的第一个,然后取第二个元素就要满足那个元素的值要小于等于二分的答案。第三个值就取我们去第二个元素后面那个就行。具体见代码

代码:

 1 #include<stdio.h>
2 #include<algorithm>
3 #include<iostream>
4 #include<string>
5 #include<queue>
6 #include<string.h>
7 #include<map>
8 #include <iostream>
9 #include <math.h>
10 using namespace std;
11 typedef long long ll;
12 const int maxn=2e5+10;
13 int n,k,a[maxn];
14 bool check(int x,bool flag)
15 {
16 int cnt=0;
17 for(int i=1; i<=n; i++)
18 {
19 if(flag||a[i]<=x)
20 {
21 cnt++;
22 flag=!flag;
23 }
24 }
25 return cnt>=k;//��û��k������������Ԫ��
26 }
27 int main()
28 {
29 scanf("%d%d",&n,&k);
30 for(int i=1; i<=n; i++)
31 {
32 scanf("%d",&a[i]);
33 }
34 int l=1,r=1e9,ans;
35 while(l<=r)
36 {
37 int mid=(l+r)/2;
38 if(check(mid,0)||check(mid,1))
39 {
40 ans=mid;
41 r=mid-1;
42 }
43 else
44 {
45 l=mid+1;
46 }
47 }
48 printf("%d\n",ans);
49 return 0;
50 }
51  

 

Codeforces Round #651 (Div. 2) A Maximum GCD、B GCD Compression、C Number Game、D Odd-Even Subsequence的更多相关文章

  1. Codeforces Round #651 (Div. 2) A. Maximum GCD(数论)

    题目链接:https://codeforces.com/contest/1370/problem/A 题意 有 $n$ 个数大小分别为 $1$ 到 $n$,找出两个数间最大的 $gcd$ . 题解 若 ...

  2. Codeforces Round #651 (Div. 2) A. Maximum GCD (思维)

    题意:在\(1\)~\(n\)中找两个不相等的数使得他们的\(gcd\)最大. 题解:水题,如果\(n\)是偶数,那么一定取\(n\)和\(n/2\),\(n\)是奇数的话,取\(n-1\)和\((n ...

  3. Codeforces Round #172 (Div. 2) D. Maximum Xor Secondary 单调栈应用

    http://codeforces.com/contest/281/problem/D 要求找出一个区间,使得区间内第一大的数和第二大的数异或值最大. 首先维护一个单调递减的栈,对于每个新元素a[i] ...

  4. Codeforces Round #651 (Div. 2) B. GCD Compression(数论)

    题目链接:https://codeforces.com/contest/1370/problem/B 题意 给出 $2n$ 个数,选出 $2n - 2$ 个数,使得它们的 $gcd > 1$ . ...

  5. Codeforces Round #651 (Div. 2) B. GCD Compression (构造)

    题意:有一个长度为\(2n\)的数组,删去两个元素,用剩下的元素每两两相加构造一个新数组,使得新数组所有元素的\(gcd\ne 1\).输出相加时两个数在原数组的位置. 题解:我们按照新数组所有元素均 ...

  6. Codeforces Round #221 (Div. 1) B. Maximum Submatrix 2 dp排序

    B. Maximum Submatrix 2 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/problemset ...

  7. Codeforces Round #276 (Div. 1) B. Maximum Value 筛倍数

    B. Maximum Value Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/484/prob ...

  8. Codeforces Round #508 (Div. 2) E. Maximum Matching(欧拉路径)

     E. Maximum Matching 题目链接:https://codeforces.com/contest/1038/problem/E 题意: 给出n个项链,每条项链左边和右边都有一种颜色(范 ...

  9. Codeforces Round #276 (Div. 1)B. Maximum Value 筛法

    D. Maximum Value     You are given a sequence a consisting of n integers. Find the maximum possible ...

随机推荐

  1. Flutter 基础组件:输入框和表单

    前言 Material组件库中提供了输入框组件TextField和表单组件Form. 输入框TextField 接口描述 const TextField({ Key key, // 编辑框的控制器,通 ...

  2. Flutter 基础组件:图片和Icon

    前言 Flutter中,可以通过Image组件来加载并显示图片,Image的数据源可以是asset.文件.内存以及网络. ImageProvider 是一个抽象类,主要定义了图片数据获取的接口load ...

  3. zabbix 4.X 版本 web字体显示方块

    先看看问题长啥样...... Zabbix 字体乱码(显示呈现方块) 第一种解决方法: # 1) 进入代码存放目录的字体目录: cd /data/www/zabbix/assets/fonts # 2 ...

  4. Python基础语法3-输入、输出语句

  5. ctfhub技能树—sql注入—布尔盲注

    打开靶机 查看页面信息 开始试验,查看返回信息 此题存在一个问题,如果没有数据,也是返回query_success 如此一来,就无法使用and组合进行注入,在看了其他大佬的解题过程后,知道了可以使用& ...

  6. 同一份数据,Redis为什么要存两次

    前言 在 Redis 中,有一种数据类型,当在存储的时候会同时采用两种数据结构来进行分别存储,那么 Redis 为什么要这么做呢?这么做会造成同一份数据占用两倍空间吗? 五种基本类型之集合对象 Red ...

  7. NAT模式、路由模式、桥接模式的区别

    NAT模式 NAT模式概述 NAT是"Network Address Translation"的缩写,中文意思是"网络地址转换",它允许一个整体机构以一个公用I ...

  8. 向HDFS中上传任意文本文件,如果指定的文件在HDFS中已经存在,由用户指定是追加到原有文件末尾还是覆盖原有的文件

    1 import java.io.FileInputStream; 2 import java.io.IOException; 3 import java.util.Scanner; 4 5 impo ...

  9. asctime_s asctime

    asctime_s  asctime // rand随机数.cpp : 此文件包含 "main" 函数.程序执行将在此处开始并结束. // #include "pch.h ...

  10. Centos虚拟机上安装部署Tenginx,以及部署过程中遇到的问题

    Tenginx下载网址: Tenginx 官网地址:http://tengine.taobao.org/ Tenginx的官方网址中可以阅读Nginx的文档,可以选择中文进行阅读.下载Tengine- ...