A。水题。

#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <string>
#include<algorithm>
using namespace std;
];
int main()
{
    int n,m;
    cin>>n>>m;
    ; i<=n; ++i) cin>>a[i];
    ;
    ;
    ; i<=n; ++i)
    {
        if(p<a[i])
        {
            p=m;
            ans++;
        }
        p-=a[i];
    }
    cout<<ans<<endl;
    ;
}

B。用字符串读入数字。对于这个数字,从左往右看,寻找交换k次之内可得的最大数字,并交换到最左边。k再减去交换步数。如此直到k为0或者该数字达它可取的最大值。

#include <cstdio>
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <string>
#include<algorithm>
using namespace std;
string num;
int k;
int main()
{
    cin>>num>>k;
    ) cout<<num<<endl;
    else
    {
        string t=num;
        sort(t.begin(),t.end(),greater<int>());
        ;
        int len=num.size();
        while(k)
        {
            if(num==t) break;
            int maxp=st;
            ; i<min(st+k+,len); ++i)
                if(num[i]>num[maxp]) maxp=i;
            for(int i=maxp; i>st; --i)
            {
                swap(num[i],num[i-]);
                k--;
            }
            st++;
        }
        cout<<num<<endl;
    }
    ;
}

C。根据计算出的数字对,画一个图。

首先计算出所有的数字对,由于有负数,为了方便可以用map<int,int>来存图。取得点可能的上下左右边界值,再遍历该空间,画图即可。

#include <iostream>
#include <cstdlib>
#include <cstring>
#include <string>
#include<algorithm>
#include<map>
using namespace std;
typedef pair<int,int> Pair;
map<Pair,int > vis;
];
int main()
{
    int n;
    cin>>n;
    ; i<=n; ++i) cin>>a[i];
    ,left=,down=,right=;
    ,y=;
    vis[Pair(x,y)]=;
    ; i<=n; ++i)
    {
        ; j<=a[i]; ++j)
        {
            x++;
            ) y++;
            else y--;
            )
                vis[Pair(x,y)]=;
            else
                vis[Pair(x,y+)]=-;
        }
        up=max(up,y);
        down=min(down,y);
        left=min(left,x);
        right=max(right,x);
    }
    for(int i=up; i>down; --i)
    {
        ; j<=right; ++j)
        {
            int &u=vis[Pair(j,i)];
            )  cout<<"/";
            )  cout<<"\\";
            else  cout<<" ";
        }
        cout<<endl;
    }
    ;
}

D。预处理+统计。

统计三角形个数。要求选定的三角形的边上不含有黑点。

明显这样图中的三角形只能是等腰直角三角形。我们可以预处理出两条对角线上的白点个数。然后枚举一个点,再递增边长,在保证两条等边不含黑点的前提下,通过判断第三条边上的白点个数来判断第三条边上是否含有黑点。

这样的三角形一共有八种。第一类是斜边在对角线上的三角形,可以枚举直角点,再递增边,判断斜边。第二类是斜边在行或列上的三角形,这样可以枚举斜边中点,沿中点递增边,然后判断两条直角边。

#include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<string>
using namespace std;
][];
][];
][],UR[][];
int main()
{
    int n,m;
    scanf("%d%d",&n,&m);
    ; i<=n; ++i)
    {
        scanf();
        ; j<=m; ++j)
            mp[i][j]=(grid[i][j]==:;
    }
    ; i<=n; ++i)
        ; j<=m; ++j)
            UL[i][j]=UL[i-][j-]+mp[i][j];
    ; i<=n; ++i)
        ; --j)
            UR[i][j]=UR[i-][j+]+mp[i][j];
    ;
    ; i<=n; ++i)
        ; j<=m; ++j)
            if(mp[i][j])
            {
                ; mp[i-d][j]&&mp[i][j-d]; ++d) //左上
                    ][j+]==d+)
                        ans++;
                ; mp[i+d][j]&&mp[i][j+d]; ++d)//右下
                    ][j+d+]==d+)
                        ans++;
                ; mp[i-d][j]&&mp[i][j+d]; ++d)//右上
                    ][j-]==d+)
                        ans++;
                ; mp[i+d][j]&&mp[i][j-d]; ++d)//左下
                    ][j-d-]==d+)
                        ans++;
                ; mp[i-d][j]&&mp[i+d][j]; ++d) //左
                    ][j+]==d+&&UL[i+d][j]-UL[i-][j-d-]==d+)
                        ans++;
                ; mp[i+d][j]&&mp[i-d][j]; ++d)//右
                    ][j-]==d+&&UR[i+d][j]-UR[i-][j+d+]==d+)
                        ans++;
                ; mp[i][j-d]&&mp[i][j+d]; ++d) //上
                    ][j+]==d+&&UL[i][j+d]-UL[i-d-][j-]==d+)
                        ans++;
                ; mp[i][j+d]&&mp[i][j-d]; ++d)//下
                    ][j+d+]==d+&&UL[i+d][j]-UL[i-][j-d-]==d+)
                        ans++;
            }
    printf("%d\n",ans);
    ;
}

E。找规律+构造。

答案大致有这么几种情况:

第一类:

1212

3434

1212

3434

或者

1232

3414

1232

1414等等

这类的特点是以左上角的四个格为单元,不断在每列上重复得到。而在每行上,可分为第一、二行交不交换几种情况。

第二类:

1212

3434

2121

3434

或者

1212

3434

2121

4343等等

这类的特点是以左上角的四个格为单元,不断在每行上重复得到。而在每列上,可分为第一、二列交不交换几种情况。

我们需要找出所有情况判断是否和给出的矩阵匹配即可。

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
#include <vector>
using namespace std;
][];
int n,m;
][];
bool judge(int x,int y)
{
    '!=arr[x][y]) return false;
    return true;
}
void output()
{
    ; i<=n; ++i)
    {
        ; j<=m; ++j)
            printf("%d",arr[i][j]);
        printf("\n");
    }
}
bool check1()
{
    ; j<=; ++j)
        ; i<=n; ++i)
        {
            arr[i][j]=arr[i-][j];
            if(!judge(i,j))
                return false;
        }
    ; j<=m; ++j)
    {
        bool ok=true;
        arr[][j]=arr[][j-];
        arr[][j]=arr[][j-];
        ,j)||!judge(,j)) ok=false;
        ; i<=n&&ok; ++i)
        {
            arr[i][j]=arr[i-][j];
            if(!judge(i,j)) ok=false;
        }
        if(ok) continue;
        ok=true;
        arr[][j]=arr[][j-];
        arr[][j]=arr[][j-];
        ,j)||!judge(,j)) ok=false;
        ; i<=n&&ok; ++i)
        {
            arr[i][j]=arr[i-][j];
            if(!judge(i,j))
                ok=false;
        }
        if(!ok) return false;
    }
    return true;
}
bool check2()
{
    ; i<=; ++i)
        ; j<=m; ++j)
        {
            arr[i][j]=arr[i][j-];
            if(!judge(i,j))
                return false;
        }
    ; i<=n; ++i)
    {
        bool ok=true;
        arr[i][]=arr[i-][];
        arr[i][]=arr[i-][];
        )||!judge(i,)) ok=false;
        ; j<=m&&ok; ++j)
        {
            arr[i][j]=arr[i][j-];
            if(!judge(i,j))
                ok=false;
        }
        if(ok) continue;
        arr[i][]=arr[i-][];
        arr[i][]=arr[i-][];
        ok=true;
        )||!judge(i,)) ok=false;
        ; j<=m&&ok; ++j)
        {
            arr[i][j]=arr[i][j-];
            if(!judge(i,j))
                ok=false;
        }
        if(!ok)  return false;
    }
    return true;
}
int main()
{
    scanf("%d%d",&n,&m);
    ; i<=n; ++i)
        scanf();
    ]= {,,,};
    do
    {
        arr[][]=p[];
        arr[][]=p[];
        arr[][]=p[];
        arr[][]=p[];
        bool ok=true;
        ; i<=&&ok; ++i)
            ; j<=&&ok; ++j)
                if(!judge(i,j))ok=false;
        if(!ok) continue;
        if(check1()||check2())
        {
            output();
            ;
        }
    }
    ));
    puts(");
    ;
}

Codeforces Round #249 (Div. 2)的更多相关文章

  1. 模拟 Codeforces Round #249 (Div. 2) C. Cardiogram

    题目地址:http://codeforces.com/contest/435/problem/C /* 题意:给一组公式,一组数据,计算得到一系列的坐标点,画出折线图:) 模拟题:蛮恶心的,不过也简单 ...

  2. Codeforces Round #249 (Div. 2) C题,模拟画图 ----未解决!

    http://codeforces.com/contest/435/problem/C

  3. Codeforces Round #249 (Div. 2)B(贪心法)

    B. Pasha Maximizes time limit per test 1 second memory limit per test 256 megabytes input standard i ...

  4. Codeforces Round #249 (Div. 2) A题

    链接:http://codeforces.com/contest/435/problem/A   A. Queue on Bus Stop time limit per test 1 second m ...

  5. Codeforces Round #249 (Div. 2) D. Special Grid 枚举

    题目链接: http://codeforces.com/contest/435/problem/D D. Special Grid time limit per test:4 secondsmemor ...

  6. Codeforces Round #249 (Div. 2) 总结

    D.E还是很难的.....C不想多说什么... A:提意:给出每一组人的个数,以及一次车载容量,求出最少需要多少次才能载走所有的人. water: http://codeforces.com/cont ...

  7. Codeforces Round #249 (Div. 2) (模拟)

    C. Cardiogram time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  8. Codeforces Round #249 (Div. 2) C. Cardiogram

    C. Cardiogram time limit per test 1 second memory limit per test 256 megabytes input standard input ...

  9. Codeforces Round #249 (Div. 2) A. Black Square

    水题 #include <iostream> #include <vector> #include <algorithm> using namespace std; ...

  10. Codeforces Round #249 (Div. 2) B. Pasha Maximizes

    看到题目的时候,以为类似插入排序,比较第i个元素和第i-1个元素, 如果第i个元素比第i-1个元素小,则不交换 如果第i个元素比第i-1个元素大,则交换第i个元素和第i-1个元素 继续比较第i-1个元 ...

随机推荐

  1. 如何在腾讯云上搭建一个人力资源Saas

    版权声明:本文由ihr原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/180 来源:腾云阁 https://www.qclo ...

  2. Unity3d多线程

    http://blog.csdn.net/dingkun520wy/article/details/49181645 (一)多线程的创建 Thread t = new Thread(new Threa ...

  3. 打开Eclipse时出现"The Eclipse executable launcher was unable to locate its companion shared library"情况的解决办法

    在网上有坑,各种解决方法都有,但似乎我这台64位机器不太给面子,都不能解决: 结果自己找到了解决办法,总结了一下,大多数软件出问题,如果卸载了重新装还是出现问题,一般都是注册表残留的问题: 将ecli ...

  4. 使用Eclipse构建Maven的SpringMVC项目

    一.直接建立Maven项目方法1.建立Maven项目 接下来使用Eclipse的maven构建一个web项目,以构建SpringMVC项目为例: 1.1 选择建立Maven Project 选择Fil ...

  5. uva 1629

    1629 - Cake slicing Time limit: 3.000 seconds A rectangular cake with a grid of m * n <tex2html_v ...

  6. das,nas,san区别——大型数据中心会用NAS+SAN软硬结合思路

    DAS(Direct Access Storage-直接连接存储)是指将存储设备通过SCSI接口或光纤通道直接连接到一台计算机上.NAS(Network Attached Storage网络连接存储) ...

  7. JDE开发端安装笔记

    JDE版本:JD Edwards EnterpriseOne 9.1.4 for Microsoft 64bit Oracle客户端:Oracle Database 11g Release 2 Cli ...

  8. JavaScript基础---作用域,匿名函数和闭包【转】

    匿名函数就是没有名字的函数,闭包是可访问一个函数作用域里变量的函数. 一.匿名函数 //普通函数 function box() { //函数名是 box return 'TT'; } //匿名函数 f ...

  9. LoadRunner 文本检查点使用

    在测试时,我们可以根据文本检查点判断事务是否执行正确.   我们在启动流程时,成功返回:   我们检查这个响应结果是否有. int i=0; i=web_reg_find("Text=\&q ...

  10. redhat enterprixe 5.0 下DHCP服务器rpm安装配置及其测试

    一.了解DHCP DHCP服务提供动态指定IP地址和配置参数的机制.有动态和静态两种方式. 二.rpm安装 因为配过Samba,所以感觉挺简单. 首先找到主程序和几个附属程序的rpm的安装包.应该都是 ...