A - Hometask

题意:给你一个字符串,然后再给你k个禁止挨在一起的字符串,问你最少删除多少个字符串,使得不会有禁忌的字符串对挨在一起。题目保证每个字符最多出现在一个禁忌中。

题解:由于每个字符只会出现在一个禁忌里面,那么就说明每个询问是独立的。对于每个询问,我们贪心的去处理就好了,就连续的禁忌字符串,我们删除少的那个就好了。

#include<bits/stdc++.h>
using namespace std;
string s,s2;
int ans,a,b,m,c,d;
int main(){
cin>>s;
cin>>m;
for(int i=0;i<m;i++){
cin>>s2;
a=0,b=0;
for(int j=0;j<s.size();j++){
if(s[j]==s2[0])
a++;
else if(s[j]==s2[1])
b++;
else
ans+=min(a,b),a=0,b=0;
}
ans+=min(a,b);
}
cout<<ans<<endl;
}

B. Colliders

题意:你要实现两个功能,加x和减x。如果是加x的话,那么如果添加x的时候如果已经添加了和他不互质的数的话,那么就输出冲突。否则就加进去。

题解:我们对于每个数的因子都预处理处理啊,这个复杂度是nlogn,然后我们再用个set维护存在这个因子的数的开启个数,然后每次暴力的修改就可以了,这个复杂度是nlognlogn的。

代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5+7;
int v[maxn],n,m,num;
vector<int>p[maxn];
set<int> S[maxn];
string op;
void pre(){
for(int i=2;i<maxn;i++){
for(int j=i;j<maxn;j+=i){
p[j].push_back(i);
}
}
}
void add(int x){
if(v[x]==1){
printf("Already on\n");
return;
}
for(int i=0;i<p[x].size();i++){
if(S[p[x][i]].size()){
printf("Conflict with %d\n",*S[p[x][i]].begin());
return;
}
}
for(int i=0;i<p[x].size();i++){
S[p[x][i]].insert(x);
}
printf("Success\n");
v[x]=1;
}
void del(int x){
if(v[x]==0){
printf("Already off\n");
return;
}
for(int i=0;i<p[x].size();i++){
S[p[x][i]].erase(x);
}
printf("Success\n");
v[x]=0;
}
int main(){
pre();
scanf("%d%d",&n,&m);
for(int i=0;i<m;i++){
cin>>op>>num;
if(op[0]=='+')
add(num);
else
del(num);
}
}

C - Double Profiles

题意:给你一个1e6个点,1e6个边的无向图,然后问你有多少对点,满足这两个点的所连接的点都完全相同。

题解:分为两种情况,(i,j)相互连接的,这样就看边左右的两个点,加上自己这个点的hash值是否相同。不相互连接的,那么显然不加上自己这个点的边集hash是一样的,那么我们排序扫一遍统计即可。

代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e6+7;
int n,m;
int g[2][maxn];
long long p[maxn],k[maxn];
int main(){
scanf("%d%d",&n,&m);
p[0]=1;
for(int i=1;i<maxn;i++)
p[i]=p[i-1]*31;
for(int i=0;i<m;i++){
scanf("%d%d",&g[0][i],&g[1][i]);
g[0][i]--,g[1][i]--;
k[g[0][i]]+=p[g[1][i]];
k[g[1][i]]+=p[g[0][i]];
}
long long ans = 0;
for(int i=0;i<m;i++){
if(k[g[0][i]]+p[g[0][i]]==k[g[1][i]]+p[g[1][i]])
ans++;
}
sort(k,k+n);
int i=0,j=1;
for(i=0;i<n;i=j){
for(j=i;k[i]==k[j]&&j<n;j++);
ans=ans+1ll*(j-i)*(j-i-1)/2;
}
cout<<ans<<endl;
}

Codeforces Round #109 (Div. 1) 题解 【ABC】的更多相关文章

  1. Codeforces Round #182 (Div. 1)题解【ABCD】

    Codeforces Round #182 (Div. 1)题解 A题:Yaroslav and Sequence1 题意: 给你\(2*n+1\)个元素,你每次可以进行无数种操作,每次操作必须选择其 ...

  2. 贪心 Codeforces Round #109 (Div. 2) B. Combination

    题目传送门 /* 贪心:按照能选的个数和点数降序排序,当条件不符合就break,水题啊! */ #include <cstdio> #include <algorithm> # ...

  3. Codeforces Round #608 (Div. 2) 题解

    目录 Codeforces Round #608 (Div. 2) 题解 前言 A. Suits 题意 做法 程序 B. Blocks 题意 做法 程序 C. Shawarma Tent 题意 做法 ...

  4. Codeforces Round #525 (Div. 2)题解

    Codeforces Round #525 (Div. 2)题解 题解 CF1088A [Ehab and another construction problem] 依据题意枚举即可 # inclu ...

  5. Codeforces Round #528 (Div. 2)题解

    Codeforces Round #528 (Div. 2)题解 A. Right-Left Cipher 很明显这道题按题意逆序解码即可 Code: # include <bits/stdc+ ...

  6. Codeforces Round #466 (Div. 2) 题解940A 940B 940C 940D 940E 940F

    Codeforces Round #466 (Div. 2) 题解 A.Points on the line 题目大意: 给你一个数列,定义数列的权值为最大值减去最小值,问最少删除几个数,使得数列的权 ...

  7. Codeforces Round #677 (Div. 3) 题解

    Codeforces Round #677 (Div. 3) 题解 A. Boring Apartments 题目 题解 简单签到题,直接数,小于这个数的\(+10\). 代码 #include &l ...

  8. Codeforces Round #665 (Div. 2) 题解

    Codeforces Round #665 (Div. 2) 题解 写得有点晚了,估计都官方题解看完切掉了,没人看我的了qaq. 目录 Codeforces Round #665 (Div. 2) 题 ...

  9. Codeforces Round #160 (Div. 1) 题解【ABCD】

    Codeforces Round #160 (Div. 1) A - Maxim and Discounts 题意 给你n个折扣,m个物品,每个折扣都可以使用无限次,每次你使用第i个折扣的时候,你必须 ...

随机推荐

  1. aliyun添加数据盘后的物理分区和lvm逻辑卷两种挂载方式

    一.普通磁盘分区管理方式 1.对磁盘进行分区 列出磁盘 # fdisk -l # fdisk /dev/vdb Welcome to fdisk (util-linux 2.23.2). Change ...

  2. 关于Java源文件中public类的问题

    结论: 一个Java源文件中最多只能有一个public类,当有一个public类时,源文件名必须与之一致,否则无法编译: 如果源文件中没有一个public类,则文件名与类中没有一致性要求: 至于mai ...

  3. PHP实现的简单组词算法

    ?php //组词算法 function diyWords($arr,$m){ $result = array(); if ($m ==1){//只剩一个词时直接返回 return $arr; } i ...

  4. spoj227 树状数组插队序列问题

    插队问题和线段树解决的方式一样,每个结点维护值的信息是该节点之前的空位有多少,然后从后往前插点即可 注意该题要求输出的是从左往右输出每个士兵的等级,即问士兵最后排在第几个位置 /* 树状数组维护前i个 ...

  5. 使用css3美化复选框

    声明:文章为转载(略改动),点击查看原文.如有侵权24小时内删除,联系QQ:1522025433. 我们知道HTML默认的复选框样式十分简陋,而以图片代替复选框的美化方式会给页面表单的处理带来麻烦,那 ...

  6. 如何将Oracle 当前日期加一天、一分钟

    在Oralce中我发现有add_months函数,加天数N可以用如下方法实现,select sysdate+N from dual sysdate+1 加一天sysdate+1/24 加1小时sysd ...

  7. 【C++】拷贝构造函数(深拷贝,浅拷贝)详解

    一.什么是拷贝构造函数  首先对于普通类型的对象来说,它们之间的复制是很简单的,例如: ; int b = a; 而类对象与普通对象不同,类对象内部结构一般较为复杂,存在各种成员变量. 下面看一个类对 ...

  8. kettle的下载、安装和初步使用(windows平台下)(图文详解)

    kettle的下载 žKettle可以在http://kettle.pentaho.org/网站下载                   http://sourceforge.net/projects ...

  9. poj 1125 谣言传播 Floyd 模板题

    假如有3个点 点1到点2要5分钟 点1到点3要3分钟 那么5分钟的时间可以传遍全图 所以要先找一个点到其他点的最长时间 再从最长的时间里找出最小值 Sample Input 3 // 结点数2 2 4 ...

  10. openstack学习-nove控制节点部署(四)

    nove在openstack非常重要,主要负责创建虚拟机 nova计算服务 API :负责接收和响应外部请求.支持openstack API,EC2 API Cert:负责身份认证EC 2 Sched ...