A,水题不多说。

#include<bits/stdc++.h>
using namespace std; //#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
int n,t; scanf("%d%d",&n,&t);
if(t<){
for(int i = n; i--;) putchar(''+t);
}else{
if(n == ) puts("-1");
else{
putchar('');
for(int i = n; --i;) putchar('');
}
}
return ;
}

A

B,用补集算一下。

#include<bits/stdc++.h>
using namespace std; const int mod = 1e9+;
typedef long long ll;
int qpow(int a,int q)
{
int re = ;
while(q){
if(q&) re = (ll)re*a%mod;
a = (ll)a*a%mod;
q >>= ;
}
return re;
} //#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
int n; scanf("%d",&n);
int ans = (qpow(,n)-qpow(,n)+mod)%mod;
printf("%d",ans);
return ;
}

B

C,当s1[i] != s2[i]的时候至少其中f值+1,效果记为10,01,11(与s1[i]和s2[i]都不同)

s1[i] == s2[i]的时候效果记为11 00。

记s[i] != s[i]有ct1个,为了保证两个f相等如果ct是奇数,单出来那个只有使得f1,f2同时加1,所以下界为low = (ct+1)/2。

其中有ct/2个对10,01 。当t<low的时候无解。

记s1[i]==s2[i]有ct2 = n-ct1个,当t>=low && t <= low+ct2的时候,只要在s1[i]==s2[i]时取相应个数个的ch,ch !=s1[i]。(11)

当t>=low+ct2的时候,需要从ct/2对中选出一些来变成 11,11

#include<bits/stdc++.h>
using namespace std; const int LEN = 1e5+;
char s[][LEN]; //#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
int n,t; scanf("%d%d\n",&n,&t);
gets(s[]); gets(s[]);
int ct1 = ;
for(int i = ; i < n; i++){
ct1 += s[][i] == s[][i];
}
int ct2 = n-ct1;
int low = (ct2+)/;
if(t < low){
puts("-1");
}else {
int pir = low - (ct2&);
int del = t - low - ct1;
int swc = , ct, ex;
if(del > ) {
ex = ct1;
ct = (pir - del)*;
}else {
ct = (pir)*;
ex = t - low;
}
for(int i = ; i < n; i++){
if(s[][i] != s[][i]){
if(ct){ //控制 01
ct--;
putchar(s[swc ^= ][i]);
}else {
for(char c = 'a'; c <= 'z'; c++){
if(c != s[][i] && c != s[][i]) {
putchar(c); break;
}
}
}
}else {
if(ex){ //控制11
ex--;
for(char c = 'a'; c <= 'z'; c++){
if(c != s[][i] && c != s[][i]) {
putchar(c); break;
}
}
}else {
putchar(s[][i]);
}
}
}
}
return ;
}

C

D,暴力,有个事实是1e9以内的的素数间隔不超过282,sqrt(N)判断一下就好了。

#include<bits/stdc++.h>
using namespace std; const int maxn = 1e5+;
int Prim[maxn], sz ;
bool vis[maxn];
void seive(int n = maxn-)
{
int m = (int)sqrt(n+0.5);
for(int i = ; i <= m; i++){
if(!vis[i])
for(int j = i*i; j <= n; j += i){
vis[j] = true;
}
}
for(int i = ; i <= n; i++){
if(!vis[i]) Prim[sz++] = i;
}
} bool chkPrime(int x)
{
int m = (int)sqrt(x+0.5);
for(int i = ; Prim[i] <= m; i++){
if(x%Prim[i] == ) return false;
}
return true;
} //#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
seive();
int n; scanf("%d",&n);
if(chkPrime(n)){
puts("");
printf("%d",n);
}else if(chkPrime(n-)){
puts("");
printf("%d %d",,n-);
}else {
puts("");
for(int i = ; ; i += ){
if(chkPrime(n-i)){
printf("%d ",n-i);
n = i;
break;
}
}
for(int i = ; Prim[i] <= n; i++){
if(chkPrime(n-Prim[i])){
printf("%d %d",Prim[i],n-Prim[i]);
break;
}
}
}
return ;
}

D

E,问交换的最小花费。看成一个置换环,最优的交换就是不断消去端点,但是这样不太好写。

一般两个排列问相对关系都可以把其中一个做映射会方便处理。把序列b映射成1...n,把a按照相同规则映射,并记录映射后元素x的位置。

从小的元素枚举,找到它在序列中的位置p[x],小的要往左边走,判断一下左边的元素是不是要往大于p[x]的位置走。如果是就交换。

p[x]的位置前面一定会有一个不小于p[x]的元素。

#include<bits/stdc++.h>
using namespace std; const int maxn = ;
int mp[maxn];
int a[maxn],p[maxn]; #define PB push_back
#define MP make_pair
#define fi first
#define se second //#define LOCAL
int main()
{
#ifdef LOCAL
freopen("in.txt","r",stdin);
#endif
int n; scanf("%d",&n);
for(int i = ; i <= n; i++){
scanf("%d",a+i);
}
for(int i = ; i <= n; i++){
int x; scanf("%d",&x);
mp[x] = i;
}
for(int i = ; i <= n; i++){
p[ a[i] = mp[a[i]] ] = i;
} int c = ;
for(int x = ; x <= n; x++){
for(int j = p[x]; --j>=x ; ){
if(a[j] >= p[x]){
c += p[x] - j;
swap(a[j],a[p[x]]);
ans.PB(MP(j,p[x]));
p[a[j]] = p[x];
p[x] = j;
}
}
} printf("%d\n",c);
printf("%d\n",(int)ans.size());
for(auto i: ans){
printf("%d %d\n",i.fi,i.se);
}
return ;
}

E

Codeforces Round #324 (Div. 2) A B C D E的更多相关文章

  1. Codeforces Round #324 (Div. 2)解题报告

    ---恢复内容开始--- Codeforces Round #324 (Div. 2) Problem A 题目大意:给二个数n.t,求一个n位数能够被t整除,存在多组解时输出任意一组,不存在时输出“ ...

  2. Codeforces Round #324 (Div. 2) C (二分)

    题目链接:http://codeforces.com/contest/734/problem/C 题意: 玩一个游戏,一开始升一级需要t秒时间,现在有a, b两种魔法,两种魔法分别有m1, m2种效果 ...

  3. Codeforces Round #324 (Div. 2) E. Anton and Ira 贪心

    E. Anton and Ira Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/584/probl ...

  4. Codeforces Round #324 (Div. 2) D. Dima and Lisa 哥德巴赫猜想

    D. Dima and Lisa Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/584/probl ...

  5. Codeforces Round #324 (Div. 2) C. Marina and Vasya 贪心

    C. Marina and Vasya Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/584/pr ...

  6. Codeforces Round #324 (Div. 2) B. Kolya and Tanya 快速幂

    B. Kolya and Tanya Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/584/pro ...

  7. Codeforces Round #324 (Div. 2) A. Olesya and Rodion 水题

    A. Olesya and Rodion Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/584/p ...

  8. Codeforces Round #324 (Div. 2) (哥德巴赫猜想)

    题目:http://codeforces.com/problemset/problem/584/D 思路: 关于偶数的哥德巴赫猜想:任一大于2的偶数都可写成两个素数之和. 关于奇数的哥德巴赫猜想:任一 ...

  9. Codeforces Round #324 (Div. 2) Dima and Lisa 哥德巴赫猜想

    原题链接:http://codeforces.com/contest/584/problem/D 题意: 给你一个奇数,让你寻找三个以内素数,使得和为这个奇数. 题解: 这题嘛...瞎比搞搞就好,首先 ...

  10. Codeforces Round #324 (Div. 2) Marina and Vasya 乱搞推理

    原题链接:http://codeforces.com/contest/584/problem/C 题意: 定义$f(s1,s2)$为$s1,s2$不同的字母的个数.现在让你构造一个串$s3$,使得$f ...

随机推荐

  1. 关于特殊目录如com null无法删除的处理办法

    1.把以下批处理做成一个del.bat放在桌面 del /f /a /q \\?\%1 rd /s /q \\?\%1 2.需要删除的文件或者文件夹拉到这个文件上就可以了 可以删除没有属性项目中没有安 ...

  2. VMware Workstation 安装以及Linux虚拟机安装 指北

    最近有挺多小伙伴跟我说起虚拟机这个东西,所以,今天就给大家写一篇虚拟机安装使用指北吧. 虚拟机(英语:virtual machine),在计算机科学中的体系结构里,是指一种特殊的软件,可以在计算机平台 ...

  3. http系列--从输入 URL 到页面加载完成的过程

    一.前言 这道题的覆盖面可以非常广,很适合作为一道承载知识体系的题目.每一个前端人员,如果要往更高阶发展,必然会将自己的知识体系梳理一遍,没有牢固的知识体系,无法往更高处走! 二.主干流程 在将浏览器 ...

  4. web综合案例01

    web综合案例01 ... .... 内容待添加

  5. PAT天梯赛L2-007 家庭房产

    题目链接:点击打开链接 给定每个人的家庭成员和其自己名下的房产,请你统计出每个家庭的人口数.人均房产面积及房产套数. 输入格式: 输入第一行给出一个正整数N(<=1000),随后N行,每行按下列 ...

  6. EIGRP-8-路由器的邻接关系

    EIGRP路由器之间会建立并维护邻接关系.EIGRP在默认情况下会动态发现邻居路由器.也可以通过工程师手动配置(静态)发现邻居.   通过向目的组播组地址224.0.0.10或FF02: : A发送E ...

  7. SVN历史版本比较中文乱码

    将Workspace的编码改为UTF-8即可,详见上图:

  8. 谈谈python修饰器

    前言 对python的修饰器的理解一直停留在"使用修饰器把函数注册为事件的处理程序"的层次,也是一知半解:这样拖着不是办法,索性今天好好整理一下关于python修饰器的概念及用法. ...

  9. Linux--2 Linux之文档与目录结构、shell基本命令

    一.Linux之文档与目录结构 1.Linux之文档与目录结构 Linux目录结构的组织形式和Windows有很大的不同.Linux没有“盘(如C盘.D盘.E盘)”的概念,而是建立一个根"/ ...

  10. OpenStack Cirros

    Cirros Openstack的开发,基本都使用这个image来测试,因为他比较小,只有10M. 镜像介绍 镜像的地址: https://launchpad.net/cirros/trunk/0.3 ...