zoukankan      html  css  js  c++  java
  • Acm(练习十)

    Acm练习(十)

    蛇形填数

    时间限制:3000 ms  |  内存限制:65535 KB
    难度:3
     
    描述
    在n*n方陈里填入1,2,...,n*n,要求填成蛇形。例如n=4时方陈为:
    10 11 12 1
    9 16 13 2
    8 15 14 3
    7 6 5 4
     
    输入
    直接输入方陈的维数,即n的值。(n<=100)
    输出
    输出结果是蛇形方陈。
    样例输入
    3
    样例输出
    7 8 1
    6 9 2
    5 4 3

    #include <iostream>
    #include <cstring>
    using namespace std;
    #define MAX_SIZE 100

    int main()
    {
        int n;
        cin >> n;//n * n方阵

        int pn[MAX_SIZE][MAX_SIZE];
        int row =-1, col = n-1;
        memset(pn, 0, sizeof(pn));//初始化为0
        int count = 1;
        while (count <= n * n)
        {
            while (row < n-1 && pn[row+1][col] == 0) pn[++row][col] = count++;
            while (col >= 1 && pn[row][col-1] == 0) pn[row][--col] = count++;
            while (row >= 1 && pn[row-1][col] == 0) pn[--row][col] = count++;
            while (col < n-1 && pn[row][col+1] == 0) pn[row][++col] = count++;
            //cout <<"count=" << count << endl;
        }
        for (int i = 0; i < n; i++)
        {
             for (int j = 0; j < n; j++)
                 cout << pn[i][j] << " ";
             cout << endl;
        }//输出

        return 0;
    }

    1.void *memset(void *s,int c,size_t n)

    总的作用:将已开辟内存空间 s 的首 n 个字节的值设为值 c。

    2.memset() 函数常用于内存空间初始化。

    char str[100];
    memset(str,0,100);

    3.memset()的深刻内涵:用来对一段内存空间全部设置为某个字符,一般用在对定义的字符串进行初始化为‘ ’或‘/0’;例:char a[100];memset(a, '/0', sizeof(a));

    memcpy用来做内存拷贝,你可以拿它拷贝任何数据类型的对象,可以指定拷贝的数据长度;例:char a[100],b[50]; memcpy(b, a, sizeof(b));注意如用sizeof(a),会造成b的内存地址溢出。

    strcpy就只能拷贝字符串了,它遇到'/0'就结束拷贝;例:char a[100],b[50];strcpy(a,b);如用strcpy(b,a),要注意a中的字符串长度(第一个‘/0’之前)是否超过50位,如超过,则会造成b的内存地址溢出。

    4.头文件<memory.h>或<string.h>

    本性的苏醒,往往在遭遇真实之后。
  • 相关阅读:
    给VS2010自动设置模板,加头注释
    使用委托解决"线程间操作无效: 从不是创建控件“textBox1”的线程访问它" 问题
    正则表达式
    用rz,sz命令在xshell传输文件
    较快的centos源
    《高性能Linux服务器构建实战》一书纠错汇总(2月14日更新)
    cat和rev
    配置centos6.0为Router
    同一个进程中生成的不同线程的栈是互相可见的
    C++用new来创建对象和非new来创建对象的区别
  • 原文地址:https://www.cnblogs.com/chance88/p/4420636.html
Copyright © 2011-2022 走看看