A:暴力从小到大枚举判断。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
signed main()
{
#ifndef ONLINE_JUDGE
freopen("a.in","r",stdin);
freopen("a.out","w",stdout);
#endif
int n=read();
for (int i=n;i<=n+10000;i++)
{
int s=0,x=i;
while (x) s+=x%10,x/=10;
if (s%4==0) {cout<<i;return 0;}
}
return 0;
//NOTICE LONG LONG!!!!!
}

  B:显然max-min<=2k时有解,最优解为min+k。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 110
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int q,n,k,a[N];
signed main()
{
q=read();
while (q--)
{
n=read(),k=read();
for (int i=1;i<=n;i++) a[i]=read();
int mn=inf,mx=0;
for (int i=1;i<=n;i++) mn=min(mn,a[i]),mx=max(mx,a[i]);
if (mx-k<=mn+k) cout<<mn+k<<endl;
else cout<<-1<<endl;
}
return 0;
//NOTICE LONG LONG!!!!!
}

  C:一点脑子都不想动可以二分答案。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 110
#define int long long
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int q,k,n,a,b;
signed main()
{
q=read();
while (q--)
{
k=read()-1,n=read(),a=read(),b=read();
if (b*n>k) printf("-1\n");
else
{
int l=0,r=n,ans=0;
while (l<=r)
{
int mid=l+r>>1;
if (a*mid+b*(n-mid)<=k) ans=mid,l=mid+1;
else r=mid-1;
}
printf("%d\n",ans);
}
}
return 0;
//NOTICE LONG LONG!!!!!
}

  D、E:跳过。

  F:当只要求选择两个数时,显然选择最大值及最大的不是其因子的数最优。因为假设次大值是最大值的因子,那么次大值<=最大值/2,如果不选择最大值,两个数的和一定不大于最大值。于是考虑枚举最大值,剩下的数按上述方法选择。可以使用set删去因子,复杂度O(nsqrt(n)log(n))但也能跑过。实际上sort后枚举最大值并暴力找去掉因子的最大数复杂度就是O(nsqrt(n))。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 200010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int q,n,a[N],b[N],t;
set<int> f;
void del(int x)
{
f.erase(x);
b[++t]=x;
}
signed main()
{
q=read();
while (q--)
{
n=read();
for (int i=1;i<=n;i++) a[i]=read();f.clear();
sort(a+1,a+n+1);n=unique(a+1,a+n+1)-a-1;
int ans=0;
for (int i=1;i<=n;i++) f.insert(a[i]);
for (int i=n;i>=1;i--)
{
t=0;
int s=a[i];f.erase(a[i]);
for (int j=1;j*j<=a[i];j++)
if (a[i]%j==0)
{
if (f.find(j)!=f.end()) del(j);
if (f.find(a[i]/j)!=f.end()) del(a[i]/j);
}
if (!f.empty())
{
int x=*(--f.end());
for (int j=1;j*j<=x;j++)
if (x%j==0)
{
if (f.find(j)!=f.end()) del(j);
if (f.find(x/j)!=f.end()) del(x/j);
}
s+=x;
}
if (!f.empty()) s+=*(--f.end());
ans=max(ans,s);
for (int j=1;j<=t;j++) f.insert(b[j]);
}
printf("%d\n",ans);
}
return 0;
//NOTICE LONG LONG!!!!!
}
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 200010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int q,n,a[N];
signed main()
{
q=read();
while (q--)
{
n=read();
for (int i=1;i<=n;i++) a[i]=read();
sort(a+1,a+n+1);n=unique(a+1,a+n+1)-a-1;
int ans=0;
for (int i=n;i>=1;i--)
{
int s=a[i];int x=0;
for (int j=i-1;j>=1;j--)
if (a[i]%a[j]) {x=j,s+=a[j];break;}
for (int j=x-1;j>=1;j--)
if (a[i]%a[j]&&a[x]%a[j]) {s+=a[j];break;}
ans=max(ans,s);
}
printf("%d\n",ans);
}
return 0;
//NOTICE LONG LONG!!!!!
}

  G:求出每种糖果数量以及其中有多少个fi=1。然后从大到小考虑礼物中的糖果数量,将糖果数量足够的糖果种类加入set,取出Σfi最大的。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 200010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int q,n;
struct data
{
int x,y;
bool operator <(const data&a) const
{
return x<a.x||x==a.x&&y<a.y;
}
}a[N],c[N];
multiset<int> f;
signed main()
{
q=read();
while (q--)
{
n=read();
for (int i=1;i<=n;i++) a[i].x=read(),a[i].y=read();
sort(a+1,a+n+1);
int m=0;
for (int i=1;i<=n;i++)
{
int t=i;
while (t<n&&a[t+1].x==a[i].x) t++;
c[++m].x=t-i+1;c[m].y=0;
for (int j=i;j<=t;j++) if (a[j].y==1) c[m].y++;
i=t;
}
sort(c+1,c+m+1);reverse(c+1,c+m+1);
int cur=0,ans=0,ans2=0;f.clear();
for (int i=n;i>=1;i--)
{
while (cur<m&&c[cur+1].x>=i)
{
f.insert(c[++cur].y);
}
if (!f.empty())
{
ans+=i;
ans2+=min(i,*(--f.end()));
f.erase(--f.end());
}
}
printf("%d %d\n",ans,ans2);
}
return 0;
//NOTICE LONG LONG!!!!!
}

  H:建出序列自动机(对每个位置求出每个字符下一次出现位置),然后dp出长度为i的本质不同子序列数量即可。注意数量对k取min。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 110
#define int long long
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,f[N][N],nxt[N][26];
ll k,ans;
char s[N];
signed main()
{
n=read();ll k;cin>>k;
scanf("%s",s+1);
ans=k*n;
for (int i=0;i<26;i++) nxt[n+1][i]=n+1;
for (int i=n;i>=1;i--)
{
for (int j=0;j<26;j++) nxt[i][j]=nxt[i+1][j]; nxt[i][s[i]-'a']=i;
}
for (int i=0;i<=n;i++) f[i][1]=1;
for (int i=2;i<=n+1;i++)
for (int j=n;j>=0;j--)
{
for (int k=0;k<26;k++)
f[j][i]+=f[nxt[j+1][k]][i-1];
f[j][i]=min(f[j][i],k);
}
for (int i=n+1;i>=1;i--)
{
if (k>f[0][i]) ans-=(i-1)*f[0][i],k-=f[0][i];
else {ans-=(i-1)*k;k=0;break;}
}
if (k) cout<<-1;else
cout<<ans;
return 0;
//NOTICE LONG LONG!!!!!
}

  小号5。result:rank 2 rating +322

Codeforces Round #570 Div. 3的更多相关文章

  1. Codeforces Round #570 (Div. 3) B. Equalize Prices

    原文链接https://codeforces.com/contest/1183/problem/B 题意:进行Q组测试,在每组中有长度为n的数组a[i],然后现在给你一个K,问你找到一个bi使得|ai ...

  2. Codeforces Round #570 (Div. 3) E. Subsequences (easy version) (搜索,STL)

    题意:有一长度为\(n\)的字符串,要求得到\(k\)不同的它的子序列(可以是空串),每个子序列有\(|n|-|t|\)的贡献,求合法情况下的最小贡献. 题解:直接撸个爆搜找出所有子序列然后放到set ...

  3. Codeforces Round #570 (Div. 3) G. Candy Box (hard version) (贪心,优先队列)

    题意:你有\(n\)个礼物,礼物有自己的种类,你想将它们按种类打包送人,但是打包的礼物数量必须不同(数量,与种类无关),同时,有些礼物你想自己留着,\(0\)表示你不想送人,问你在送出的礼物数量最大的 ...

  4. Codeforces Round #570 (Div. 3) B. Equalize Prices、C. Computer Game、D. Candy Box (easy version)、E. Subsequences (easy version)

    B题题意: 给你n个物品的价格,你需要找出来一个值b,使得每一个物品与这个b的差值的绝对值小于k.找到最大的b输出,如果找不到,那就输出-1 题解: 很简单嘛,找到上下限直接二分.下限就是所有物品中最 ...

  5. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  6. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  7. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  8. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  9. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

随机推荐

  1. 金字塔原理(Pyramid Principle)

    什么是金字塔原理?简单来说,金字塔原理就是“中心论点---分论点---支撑论据”这样的一个结构. 图片摘自:http://www.woshipm.com/pmd/306704.html 人类通常习惯于 ...

  2. js中forEach,for in,for of循环的用法详解

    一.一般的遍历数组的方法: var array = [1,2,3,4,5,6,7]; for (var i = 0; i < array.length; i) { console.log(i,a ...

  3. mvn pom文件引用顺序关系

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  4. linux学习(1):linux命令大全

    Linux命令 目录 1       文件管理... 5 1.1          basename. 5 1.2          cat 5 1.3          cd. 5 1.4      ...

  5. beyond compare解决特殊字符无法输出、多sheet页无法对比以及文件太大超出系统内存问题的Excel转txt脚本

    beyond compare解决特殊字符无法输出.多sheet页无法对比以及文件太大超出系统内存问题的Excel转txt脚本 ' XLS_to_CSV.vbs ' ' Converts an Exce ...

  6. semi-join子查询优化 -- Duplicate Weedout策略

    duplicate weedout是执行semi-join子查询的一种策略. 将semi-join作为一个常规的inner join.然后使用一个临时表,将重复的记录排除. 假设,你有一个查询,你在寻 ...

  7. electron---项目打包

    创建一个应用目录:app,里面需要有必要的三个文件: index.html <!DOCTYPE html> <html> <head> <meta chars ...

  8. ISO/IEC 9899:2011 附录C——顺序点

    附录C——顺序点 1.以下是在5.1.2.3中所描述的顺序点(sequence point): ——在一个函数调用中的函数指示符(function designator)和实际参数的计算,与实际调用之 ...

  9. linux中环境变量和系统加载环境变量的顺序

    一.系统环境变量: /etc/profile :这个文件预设了几个重要的变量,例如PATH, USER, LOGNAME, MAIL, INPUTRC, HOSTNAME, HISTSIZE, uma ...

  10. Qt QtXml读取xml文件内容

    Qt QtXml读取xml文件内容 xml文件内容 <?xml version="1.0" encoding="UTF-8"?> <YG_RT ...