CQ18阶梯赛第二场

news/2025/1/13 7:41:20/

H国的身份证号码I HihoCoder - 1558 

只要单纯的判断一下前后的乘积就好了, 因为不是很想处理倍数的关系, 所以我这里是用 string去处理。

代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define LL long long
 4 #define ULL unsigned LL
 5 #define fi first
 6 #define se second
 7 #define lson l,m,rt<<1
 8 #define rson m+1,r,rt<<1|1
 9 #define max3(a,b,c) max(a,max(b,c))
10 const int INF = 0x3f3f3f3f;
11 const LL mod = 1e9+7;
12 typedef pair<int,int> pll;
13 char str[10];
14 int n, k;
15 bool add(){
16     for(int i = n - 1; i >= 1; i--){
17         if((str[i-1]-'0')*(str[i]-'0'+1) <= k && str[i]-'0'+1 <= k) {str[i] = str[i] + 1;return true;}
18         else str[i] = '0';
19     }
20     if(str[0]-'0'+1 <= k) {str[0] = str[0]+1; return true;}
21     return false;
22 }
23 int main(){
24     scanf("%d%d",&n,&k);
25     str[0] = '1';
26     for(int i = 1; i < n; i++) str[i] = '0';
27     str[n] = '\0';
28     while(1){
29             printf("%s\n", str);
30         if(!add())  break;
31     }
32     return 0;
33 }
View Code

 

偶像的条件 HihoCoder - 1514 

求最小的D,D=|Ai-Bj|+|Bj-Ck|+|Ck-Ai|

假设A > B > C , D = 2(A - C)。 假设 A > C > B , D = 2(A - B)。

我们可以发现 D 就等于最大的那个数减去最小的那个数 再乘以2, 所以我们直接去对A,B,C的大小关系进行全排列, 然后对于每个a[i], 找到大于等于a[j],且最小的b[j], 再找到大于等于b[j]的最小的c[k], 求出每一个成立的 (c[k]-a[i])并取其中最小的那个就好了。

代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define LL long long
 4 #define ULL unsigned LL
 5 #define fi first
 6 #define se second
 7 #define lson l,m,rt<<1
 8 #define rson m+1,r,rt<<1|1
 9 #define max3(a,b,c) max(a,max(b,c))
10 const int INF = 0x3f3f3f3f;
11 const LL mod = 1e9+7;
12 typedef pair<int,int> pll;
13 const int N = 100010;
14 int A[N], B[N], C[N];
15 int ans = 1e9;
16 void solve(int a[], int n, int b[], int m, int c[], int l){
17     for(int i = 1; i <= n; i++){
18         int p1 = lower_bound(b+1,b+1+m,a[i]) - b;
19         if(p1 == m+1) return;
20         int p2 = lower_bound(c+1,c+1+l,b[p1]) - c;
21         if(p2 == l+1) return;
22         ans = min(ans, 2*(c[p2]-a[i]));
23     }
24 }
25 int main(){
26     int n, m, l;
27     scanf("%d%d%d",&n,&m,&l);
28     for(int i = 1; i <= n; i++)
29         scanf("%d",&A[i]);
30     for(int i = 1; i <= m; i++)
31         scanf("%d",&B[i]);
32     for(int i = 1; i <= l; i++)
33         scanf("%d",&C[i]);
34     sort(A+1, A+1+n);
35     A[n+1] = 1e9;
36     sort(B+1, B+1+m);
37     B[m+1] = 1e9;
38     sort(C+1, C+1+l);
39     C[l+1] = 1e9;
40     solve(A,n,B,m,C,l);
41     solve(A,n,C,l,B,m);
42     solve(B,m,A,n,C,l);
43     solve(B,m,C,l,A,n);
44     solve(C,l,A,n,B,m);
45     solve(C,l,B,m,A,n);
46     printf("%d", ans);
47     return 0;
48 }
View Code

 

数组去重 HihoCoder - 1376 

代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define LL long long
 4 #define ULL unsigned LL
 5 #define fi first
 6 #define se second
 7 #define lson l,m,rt<<1
 8 #define rson m+1,r,rt<<1|1
 9 #define max3(a,b,c) max(a,max(b,c))
10 const int INF = 0x3f3f3f3f;
11 const LL mod = 1e9+7;
12 typedef pair<int,int> pll;
13 
14 int main(){
15     int n, last, t;
16     while(~scanf("%d",&n), n != -1){
17         for(int i = 1; i <= n; i++){
18             scanf("%d", &t);
19             if(i == 1){printf("%d",t); last = t;}
20             if(last != t){
21                 printf(" %d", t);
22                 last = t;
23             }
24         }
25         printf("\n");
26     }
27     return 0;
28 }
View Code

 

分数调查 HihoCoder - 1515 

求的是查询的时候输出X同学与Y同学之间的分数差距(不清楚输出-1),莫非用最短路跑出所有点之间的距离? N = 1e5。 就算不T数组也开不下。 

后来发现可以跑出2个人之间的关系,并且建立能联通的人之间的相对关系就好了, 将第一个人的分数设为0, 然后通过边的关系处理出别人的分数。

然后每次询问的时候,判断X与Y是不是同一次访问的,如果是输出分数差,如果不是就输出-1。

代码:

 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define LL long long
 4 #define ULL unsigned LL
 5 #define fi first
 6 #define se second
 7 #define lson l,m,rt<<1
 8 #define rson m+1,r,rt<<1|1
 9 #define max3(a,b,c) max(a,max(b,c))
10 const int INF = 0x3f3f3f3f;
11 const LL mod = 1e9+7;
12 typedef pair<int,int> pll;
13 const int N = 100010;
14 int vis[N], val[N], head[N];
15 struct Node{
16     int to;
17     int ct;
18     int nt;
19 }e[N<<1];
20 int tot = 0;
21 void add(int u, int v, int w){
22     e[tot].to = v;
23     e[tot].ct = w;
24     e[tot].nt = head[u];
25     head[u] = tot++;
26 }
27 void dfs(int u, int cnt){
28     vis[u] = cnt;
29     for(int i = head[u]; ~i; i = e[i].nt){
30         if(!vis[e[i].to]){
31             val[e[i].to] = val[u]-e[i].ct;
32             dfs(e[i].to,cnt);
33         }
34     }
35 }
36 int main(){
37     memset(head, -1, sizeof(head));
38     int n, m, q;
39     int u, v, w;
40     scanf("%d%d%d", &n, &m, &q);
41     for(int i = 1; i <= m; i++){
42         scanf("%d%d%d",&u,&v,&w);
43         add(u,v,w);
44         add(v,u,-w);
45     }
46     int cnt = 1;
47     for(int i = 1; i <= n; i++){
48         if(!vis[i]){
49           val[i] = 0;
50           dfs(i,cnt++);
51         }
52     }
53     for(int i = 1; i <= q; i++){
54         scanf("%d%d",&u,&v);
55         if(vis[u] != vis[v]) printf("-1\n");
56         else printf("%d\n",val[u]-val[v]);
57     }
58     return 0;
59 }
View Code

 

转载于:https://www.cnblogs.com/MingSD/p/8505994.html


http://www.ppmy.cn/news/183361.html

相关文章

Python基于cq-http协议端,使用nonebot2框架制作属于自己的智能机器人

1. 快速创建QQ机器人 WebQQ介绍 WebQQ腾讯公司推出的使用网页方式上QQ的服务&#xff0c;特点是无需下载和安装QQ软件&#xff0c;只要能打开WebQQ的网站就可以登录QQ与好友保持联系。具有Web产品固有的便利性&#xff0c;同时在Web上最大限度的保持了客户端软件的操作习惯。…

无线智能插座Android Studio开发工具MQTTjar包下载配置

该无线智能插座的Android Studio开发工具的MQTTjar包的下载和配置详细步骤如下所示。 (1)Android Studio开发工具的MQTTjar包的下载 Android Studio开发工具的MQTTjar包的下载链接为:https://share.weiyun.com/7hTnSUEx,密码在文章的末尾,复制粘贴到浏览器打开即可,下载…

五种方法提升Midjourney的出图品质

本文基于B站UP主琥珀川Eric的《五种方法提升Midjourney出图品质》制作在此感谢大神的分享。 本文全面介绍以上五种提升Midjourney出图品质的方法&#xff0c;简单实用&#xff0c;马上就可以用上。Lets go&#xff01;&#xff01;&#xff01; 方法一 使用相机参数创建逼真的图…

【LeetCode热题100】打卡第11天:有效括号合并两个有序链表

文章目录 【LeetCode热题100】打开第11天⛅前言&#x1f512;有效括号&#x1f511;题解&#x1f512;合并两个有序链表&#x1f511;题解&#x1f4a1;思路一&#xff1a;合并到第三方链表上&#x1f510;【非递归实现】&#x1f510;【递归实现】 &#x1f4a1;思路二 &#…

Linux NGINX 优化与防盗链

----------------隐藏版本号------------------- 可以使用 Fiddler 工具抓取数据包&#xff0c;查看 Nginx版本&#xff0c; 也可以在 CentOS 中使用命令 curl -I http://192.168.80.101 显示响应报文首部信息。 curl -I http://192.168.80.101 方法一&#xff1a;修改配置文件…

C++服务器框架开发8——日志系统LogFormatter_3/override/宏定义优化switchcase结构

该专栏记录了在学习一个开发项目的过程中遇到的疑惑和问题。 其教学视频见&#xff1a;[C高级教程]从零开始开发服务器框架(sylar) 上一篇&#xff1a;C服务器框架开发7——日志系统LogFormatter_2 C服务器框架开发8——日志系统LogFormatter_3/override/宏定义优化switchcase…

Measurement Studio 2019 f3 Crack

Measurement Studio是Microsoft Visual Studio的扩展软件&#xff0c;提供了用于创建测试和测量应用程序的.NET工具。 了解Measurement Studio的功能 Measurement Studio是​唯一​一​款.NET​工具​套​件&#xff0c;专为在Microsoft Visual Studio中构建工程应用&#xff0…

C++类和对象 -- 知识点补充

补充 const成员函数static成员友元内部类匿名对象拷贝对象时的一些编译器优化 const成员函数 将const修饰的成员函数称为const成员函数&#xff0c;const修饰类成员函数&#xff0c;实际是修饰该成员函数隐含的this指针&#xff0c;表明在该成员函数中不能对类的成员进行修改。…