A

link



很简单

遍历,判断模\(k\)是否为\(0\),如果为\(0\),输出\(a_i/k\)。

点击查看代码
#include<bits/stdc++.h>

using namespace std;

int n,k;
int a[105]; signed main(){ cin >> n >> k; for(int i = 1;i <= n;++ i){
cin >> a[i];
if(a[i]%k == 0) cout << a[i]/k << " ";
} return 0; }

B

link



前置知识:\(map\)

\(map\)类似数组,如\(a_b\),\(a\),\(b\)均可为任何类型,如字符串,大概意思就是,\(a\)对应\(b\)。

遍历每一个子串,看看这个子串在前面出没出现过,没出现过,答案加\(1\)。

怎样遍历子串。

首先两重循环,枚举子串的左右边界,在用一重循环,枚举在当前边界内每一个字符,组成子串。

怎样判断子串出没出过。

使用\(map\),看看\(map\)的当前字符串是否为\(1\),是,出现过,否,没出现过,答案加一,赋为\(1\),即出现过了。

点击查看代码
#include<bits/stdc++.h>

using namespace std;

char s[105];
int n;
string t;
map<string,int> mp;
int ans; signed main(){ cin >> s+1;
n = strlen(s+1); for(int i = 1;i <= n;++ i){
for(int j = i;j <= n;++ j){
t.clear();
for(int k = i;k <= j;++ k){
t += s[k];
}
if(!mp[t]) mp[t] = 1,ans++;
}
} cout << ans; return 0; }

C

link



首先,把每一个对应到第一周的上班日和第二周的休息日中。

那么只需要往后移动,把第一周上班日中的全移到第二周休息日,同时第二周休息日中的不能移出去。

找到这些中最大的和最小的(改后的数),如果大于休息日的时间,即会移出去,不可以。

还有一种方案,我们可以从前面截一段放到后面再判断。

点击查看代码
#include<bits/stdc++.h>

#define int long long

using namespace std;

int n,a,b;
int p[200005];
int d,ans = 1e18;
int ma,mi = 1e18; signed main(){ cin >> n >> a >> b;
for(int i = 1;i <= n;++ i){
cin >> d;
d %= (a+b);
if(d == 0) d = a+b;
if(d <= a){
d += a+b;
}
ma = max(ma,d);
mi = min(mi,d);
p[i] = d;
} sort(p+1,p+1+n); for(int i = 1;i < n;++ i){
ans = min(ans,a+b-p[i+1]+p[i]+1);
} ans = min(ans,ma-mi+1);
if(ans <= a) cout << "Yes";
else cout << "No"; return 0; }

D

link



首先,我们定义一个\(cy\)为\(y\)中\(1\)的个数。

则,如果\(cy>a+b\),肯定不行。

如果\(cy=a+b\),把\(a\)个\(1\)给第一个数,\(b\)个\(1\)给第二个数,要对应到位置,即可。

如果\(cy<a+b\),\(a\)和\(b\)剩的是单数,不可以,双数可以。

双数的话,首先,在\(a\)和\(b\)中把多出来的平分去掉,剩下的把\(a\)个\(1\)给第一个数,\(b\)个\(1\)给第二个数,找够第一个和第二个数都是\(0\)的位置都赋成\(1\),即可。

注意不超过\(2^{60}\)。

点击查看代码
#include<bits/stdc++.h>

#define int long long

using namespace std;

int a,b,c,cy;
int ca[65];
int aa[65],ba[65]; signed main(){ cin >> a >> b >> c; int t = c;
for(int i = 0;i <= 59;++ i){
if(t&1) ca[i] = 1,cy++;
t >>= 1;
} if(cy > a+b||(a+b-cy)%2 != 0){
cout << -1;
return 0;
} int mu = (a+b-cy)/2;
a -= mu,b -= mu; for(int i = 0;i <= 59;++ i){
if(ca[i]){
if(a) aa[i] = 1,a--;
else if(b) ba[i] = 1,b--;
}
} if(a < 0||b < 0){
cout << -1;
return 0;
} for(int i = 0;i <= 59;++ i){
if(!ca[i]){
if(mu){
aa[i] = 1;
ba[i] = 1;
mu--;
}
}
} if(mu){
cout << -1;
return 0;
} int y,e,w;
y = e = 0ll;
w = 1ll; for(int i = 0;i <= 59;++ i){
if(aa[i]) y += w;
if(ba[i]) e += w;
w *= 2;
} cout << y << " " << e << endl; return 0; }

随机推荐

  1. 数据结构(C++)--学习单链表时发现的一些小坑

    基于类的链表类无相应构造函数报错 #include<bits/stdc++.h> using namespace std; const int MaxSize = 10; template ...

  2. HTML——input之密码框

    在 HTML 中,把 <input> 标签的 type 属性设置为 password 可以表示密码框.具体语法格式如下: <input type="password&quo ...

  3. Tkinter界面实操

    常用opencv-python进行图像处理,有时需要图形用户界面,写个Demo以备不时之需. Tkinter 1. 导入库 由于 Tkinter 是内置到 python 的安装包中.只要安装好 Pyt ...

  4. QuartusII调用 PLL_IP核方法(Mega Wizard)

    [基本信息] 要求:调用PLL-IP核,50Mhz晶振输入,输出四路时钟不同信号:100Mhz,25Mhz,50Mhz(90°相位),50Mhz(20%占空比). 芯片型号:cyclone Ⅳ EP4 ...

  5. MySQL学习笔记-存储引擎

    存储引擎 一. MySQL体系结构 MySQL Server 连接层:连接的处理.认证授权.安全方案.检查是否超过最大连接数等. 服务层:SQL接口.解析器.查询优化器.缓存 引擎层:引擎是数据存储和 ...

  6. Asp.Net 单点登录(SSO)|禁止重复登陆|登录强制下线

    背景: 先上个图,看一下效果: SSO英文全称Single Sign On(单点登录).SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.它包括可以将这次主要的登录映射到其 ...

  7. MS SQL SERVER 创建表、索引、添加字段等常用脚本

    创建表: if not exists ( select 1 from sysobjects where id=object_id('PayChannelNm') ) create table [dbo ...

  8. 一款.NET开源、功能强大、跨平台的绘图库 - OxyPlot

    前言 今天大姚给大家分享一款.NET开源(MIT License).免费.跨平台.功能强大的绘图库,支持多平台使用(包括:WPF.UWP.WinForm.Silverlight.Xamarin.iOS ...

  9. spring eureka服务注册配置,排查服务注册上来了,但是请求没有过来。检查是否服务注册配置错误

    spring eureka服务注册配置,排查服务注册上来了,但是请求没有过来.检查是否服务注册配置错误 解决方法: 去掉该配置eureka.instance.hostname = client微服务的 ...

  10. 关于Lecture2建立一个Git远程仓库的补充

    Smiling & Weeping ---- 心之何如,有似万丈迷津, 遥亘千里. 其中并无舟子可渡人, 除了自渡,他人爱莫能助. Git 远程仓库(Github) Git 并不像 SVN 那 ...