| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 987 人关注过本帖
标题:我要把我之前的帖子都删掉,然后以一个神的形象出现在bccn
只看楼主 加入收藏
wangnannan
Rank: 18Rank: 18Rank: 18Rank: 18Rank: 18
等 级:贵宾
威 望:87
帖 子:2546
专家分:9359
注 册:2007-11-3
收藏
得分:0 
目测 看了下楼主的陈年老贴 https://bbs.bccn.net/thread-350824-4-1.html
楼主能够说自己以前的帖子幼稚 恭喜楼主长大了

[ 本帖最后由 wangnannan 于 2015-6-4 11:58 编辑 ]

出来混,谁不都要拼命的嘛。 。拼不赢?那就看谁倒霉了。 。有机会也要看谁下手快,快的就能赢,慢。 。狗屎你都抢不到。 。还说什么拼命?
2015-06-04 10:56
zklhp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:china
等 级:贵宾
威 望:254
帖 子:11485
专家分:33241
注 册:2007-7-10
收藏
得分:0 
以下是引用wangnannan在2015-6-4 10:56:47的发言:

目测 看了下楼主的陈年老贴 https://bbs.bccn.net/thread-350824-4-1.html

2015-06-04 11:53
纳兰伽香
Rank: 10Rank: 10Rank: 10
来 自:北京
等 级:贵宾
威 望:10
帖 子:426
专家分:1650
注 册:2015-4-5
收藏
得分:1 
以下是引用wangnannan在2015-6-4 10:56:47的发言:

目测 看了下楼主的陈年老贴 https://bbs.bccn.net/thread-350824-4-1.html
楼主能够说自己以前的帖子幼稚 恭喜楼主长大了

楼主当年 太霸气

风回小院庭芜绿,柳眼春相续
2015-06-04 15:05
冰镇柠檬汁儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:北京
等 级:版主
威 望:120
帖 子:8078
专家分:6657
注 册:2005-11-7
收藏
得分:0 
以下是引用BlueGuy在2015-6-4 10:36:31的发言:

比你的帖子成熟很多了

https://bbs.bccn.net/thread-361127-1-1.html
好吧,你赢了

本来无一物,何处惹尘埃
It is empty at all here, Why pm 2.5 is so TMD high!
2015-06-04 16:58
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
回复 14楼 冰镇柠檬汁儿
你应该看看我 2011年1月 写的广度优先搜索
https://bbs.bccn.net/thread-331463-1-1.html

程序代码:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#define NUM 5

typedef struct bgMatrix
{
    int v, w;
    char matrix[NUM][NUM];
    int pre;
}Matrix;

typedef struct bgQueue
{
    Matrix* data;
    int maxLength;
    int head;
    int tail;
}BGQueue;
typedef BGQueue* Queue;

typedef struct bgStack
{
    Matrix* data;
    int top;
}BGStack;
typedef BGStack* Stack;

char srcMatrix[NUM][NUM] = 
{
    {'*', '*', '*', '*', '*'},
    {'*', '2', '8', '3', '*'},
    {'*', '1', '0', '4', '*'},
    {'*', '7', '6', '5', '*'},
    {'*', '*', '*', '*', '*'}
};

char dstMatrix[NUM][NUM] = 
{
    {'*', '*', '*', '*', '*'},
    {'*', '1', '2', '3', '*'},
    {'*', '8', '0', '4', '*'},
    {'*', '7', '6', '5', '*'},
    {'*', '*', '*', '*', '*'}
};

int dx[4] = {0, -1, 0, 1};

int dy[4] = {-1, 0, 1, 0};

int cnt = -1;

Queue queue;

Stack stack;

FILE* log;

void bfs(Matrix matrix);

void initQueue(int length);

void putQueue(Matrix matrix);

Matrix getQueue(void);

int isQueueEmpty(void);

int isQueueFull(void);

void initStack(int length);

void pushStack(Matrix matrix);

Matrix popStack(void);

int isStackEmpty(void);

int matrixCmp(char src[][NUM], char dst[][NUM]);

void matrixCpy(char dst[][NUM], char src[][NUM]);

void matrixPrint(char matrix[][NUM]);

void bgOpenLog(void);

void bgWriteLog(const char* s);

void bgCloseLog(void);

int main(void)
{
    Matrix src;
    
    bgOpenLog();
    
    initQueue(3628800);
    initStack(1000);

    src.v = 2;
    src.w = 2;
    matrixCpy(src.matrix, srcMatrix);
    src.pre = cnt;
    
    bfs(src);
    
    bgCloseLog();
    
    getchar();
    
    return 0;
}

void bfs(Matrix matrix)
{ 
    Matrix s, t;
    
    int v, w;
    
    int direction, tmp;
    
    putQueue(matrix);
    
    while (!isQueueEmpty())
    {
        t = getQueue();
        
        if (!matrixCmp(t.matrix, dstMatrix))
        {
            cnt++;
            
            for (direction = 0; direction < 4; direction++)
            {
                s = t;
                v = s.v + dx[direction]; w = s.w + dy[direction];
                
                if (srcMatrix[v][w] != '*')
                {
                    tmp = s.matrix[s.v][s.w];
                    s.matrix[s.v][s.w] = s.matrix[v][w];
                    s.matrix[v][w] = tmp;
                    
                    s.v = v;
                    s.w = w;
                    s.pre = cnt;
                    
                    for (tmp = 0; tmp < queue->tail; tmp++)
                    {
                        if (matrixCmp(queue->data[tmp].matrix, s.matrix))
                        {
                            break;
                        }
                    }
                    if (tmp == queue->tail)
                    {
                        putQueue(s);
                    }
                }
            }
        }
        else
        {
            pushStack(t);
            
            for (tmp = t.pre; !matrixCmp(queue->data[tmp].matrix, srcMatrix); tmp = queue->data[tmp].pre)
            {
                pushStack(queue->data[tmp]);
            }

            matrixCpy(t.matrix, srcMatrix);
            pushStack(t);

            while (!isStackEmpty())
            {
                t = popStack();
                matrixPrint(t.matrix);
            }

            printf("Hi, BlueGuy");

            return;
        }
    }
}

void initQueue(int length)
{ 
    queue = malloc(sizeof(BGQueue));
    
    queue->data = malloc(sizeof(Matrix) * length); 
    queue->maxLength = length; 
    queue->head = 0;
    queue->tail = 0;
}

void putQueue(Matrix matrix)
{ 
    queue->data[queue->tail++] = matrix; 
    queue->tail = queue->tail % queue->maxLength;
}

Matrix getQueue(void)
{
    Matrix ret;
    
    ret = queue->data[queue->head++];
    queue->head = queue->head % queue->maxLength; 
    
    return ret; 
}

int isQueueEmpty(void)
{
    return queue->head == queue->tail; 
}

int isQueueFull(void)
{
    return ((queue->tail+1) % queue->maxLength) == queue->head;
}

void initStack(int length)
{
    stack = malloc(sizeof(BGStack));
    
    stack->data = malloc(sizeof(Matrix) * length); 
    stack->top = 0; 

}

void pushStack(Matrix matrix)
{

    stack->data[stack->top++] = matrix; 
}

Matrix popStack(void)
{
    Matrix ret;
    ret = stack->data[--stack->top];
    
    return ret;
}

int isStackEmpty(void)
{
    return (stack->top == 0); 
}



int matrixCmp(char src[][NUM], char dst[][NUM])
{
    int i, j, s, t, ret;
    
    char srcString[30] = {0};
    char dstString[30] = {0};
    
    s = 0;
    t = 0;
    
    for (i = 0; i < NUM; i++)
    {
        for (j = 0; j < NUM; j++)
        {
            srcString[s++] = src[i][j];
            dstString[t++] = dst[i][j];
        }
    }
    
    ret = !strcmp(srcString, dstString);
    
    return ret;
}


void matrixCpy(char dst[][NUM], char src[][NUM])
{
    int i, j;
    
    for (i = 0; i < NUM; i++)
    {
        for (j = 0; j < NUM; j++)
        {
            dst[i][j] = src[i][j];
        }
    }
}

void matrixPrint(char matrix[][NUM])
{
    char logTxt[60] = {0};
    
    int i, j, k;
    
    k = 0;
    
    for (i = 0; i < NUM; i++)
    {
        for (j = 0; j < NUM; j++)
        {
            logTxt[k++] = matrix[i][j];
        }
        
        logTxt[k++] = '\r';
        logTxt[k++] = '\n';
    }
    
    logTxt[k++] = '\r';
    logTxt[k++] = '\n';
    
    bgWriteLog(logTxt);
    
}

void bgOpenLog(void)
{
    if(log == NULL)
    {
        log = fopen("log.txt", "wb");
    }
}

void bgWriteLog(const char* s)
{
    fwrite(s, sizeof(char), strlen(s), log);
}

void bgCloseLog(void)
{
    fclose(log);
    log = NULL;
}


[ 本帖最后由 BlueGuy 于 2015-6-4 17:57 编辑 ]

我就是真命天子,顺我者生,逆我者死!
2015-06-04 17:30
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
我觉得我写代码你看不懂

我就是真命天子,顺我者生,逆我者死!
2015-06-04 17:57
纳兰伽香
Rank: 10Rank: 10Rank: 10
来 自:北京
等 级:贵宾
威 望:10
帖 子:426
专家分:1650
注 册:2015-4-5
收藏
得分:0 
以下是引用BlueGuy在2015-6-4 17:57:26的发言:

我觉得我写代码你看不懂

感觉你  满腔愤恨   说话可以换很多种方式的

风回小院庭芜绿,柳眼春相续
2015-06-04 17:59
冰镇柠檬汁儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:北京
等 级:版主
威 望:120
帖 子:8078
专家分:6657
注 册:2005-11-7
收藏
得分:0 
光辉岁月啊

看你以前的帖子一样是喜欢说别人的不是,就只有你厉害呗,你赢了,我认输了,行了吧,我实在是不会贬低别人

本来无一物,何处惹尘埃
It is empty at all here, Why pm 2.5 is so TMD high!
2015-06-04 18:02
冰镇柠檬汁儿
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:北京
等 级:版主
威 望:120
帖 子:8078
专家分:6657
注 册:2005-11-7
收藏
得分:0 
以下是引用纳兰伽香在2015-6-4 17:59:22的发言:


感觉你  满腔愤恨   说话可以换很多种方式的

能说出那种话,不就证明他的幼稚吗

本来无一物,何处惹尘埃
It is empty at all here, Why pm 2.5 is so TMD high!
2015-06-04 18:03
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:0 
回复 17楼 纳兰伽香
https://bbs.bccn.net/thread-443607-2-1.html
上次给你写的组合代码,你现在看懂了么?我怀疑你还是看不懂

我就是真命天子,顺我者生,逆我者死!
2015-06-04 18:31
快速回复:我要把我之前的帖子都删掉,然后以一个神的形象出现在bccn
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.041652 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved