| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1854 人关注过本帖
标题:求C语言地图四染色代码..
只看楼主 加入收藏
ebao
Rank: 2
来 自:杭州
等 级:论坛游民
帖 子:33
专家分:66
注 册:2011-3-9
结帖率:100%
收藏
已结贴  问题点数:40 回复次数:3 
求C语言地图四染色代码..
详细注解下...
搜索更多相关主题的帖子: C语言 地图 
2011-04-09 20:50
qq1023569223
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:湖南科技大学
等 级:贵宾
威 望:26
帖 子:2753
专家分:13404
注 册:2010-12-22
收藏
得分:28 
没听过

   唯实惟新 至诚致志
2011-04-09 23:22
ebao
Rank: 2
来 自:杭州
等 级:论坛游民
帖 子:33
专家分:66
注 册:2011-3-9
收藏
得分:0 
那个悲剧啊....那哪位知道的解释下红色部分作用,,,我想不出它怎么判断的
程序代码:
#include<stdafx.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#define INIT_STACK_SIZE 10
#define STACKINREMENT 5
typedef struct{
    int * top;
    int * base;
    int stacksize;
}SqStack;

int checkMap(int , SqStack &, int );
void Push(SqStack &, int);
int Pop(SqStack &);

int MAP[20][20] ;
int locationNum ;

 /* 
int MAP[7][7] = {{0, 1, 1, 1, 1, 1, 0},
    {1 ,0 ,0, 0, 0, 1, 0},
    {1, 0, 0, 1, 1, 0, 0},
    {1, 0, 1, 0, 1, 1, 0},
    {1, 0, 1, 1, 0, 1, 0},
    {1, 1, 0, 1, 1, 0, 0},
    {0, 0, 0, 0, 0, 0, 0}};
*/
void PaintMap()
{
    void GetMap();
    SqStack stack;
    stack.base = (int *)malloc(INIT_STACK_SIZE *sizeof(int));
    stack.top = stack.base;
    stack.stacksize = INIT_STACK_SIZE;
    *stack.top++  = 1;

    int color = 1;   int section = 2;
    int mark = 0;

    GetMap() ; /*要求用户输入地图*/
   
    while ( section<=locationNum)
    {
        while(( color <= 4)&&(section <= locationNum)) 
        {
           mark = checkMap(section, stack, color);
              // 若不相邻,或若相邻且不重色,对下一个区域判断。
           if (mark < section)   color = color + 1; //相邻且重色
           else
           {
               Push(stack, color);  section = section + 1;  color = 1;
           }//相邻且不重色
       }
       if(color > 4)
       {
           section = section - 1;   color = Pop(stack) + 1;
       }
    }
   
    printf("染色的结果是  :\n" );
    for(int i = 0; i < locationNum ; i++)
        printf("%d  ", *(stack.base + i));
    printf("\n");
   
}

/*************************************************
要求用户输入地图的有关信息
*************************************************/
void GetMap(){

    printf("需要染色的地区数 : ");
    scanf("%d", &locationNum);
   
    while(getchar() != '\n');

    printf("输入地图 : \n");
    for(int i = 0 ; i < locationNum ; i++)
    {  
        char ch , lastCh ; int num = 0;
        printf("与第 %d 号区域相邻的所有区域号 : " , i + 1);
        while((ch = getchar()) != '\n')
        {  
            if(ch == ' ' ){
                MAP[i][num - 1] = 1 ;
                num = 0;
            }else
                num = num * 10 + (ch - '0') ;
            lastCh = ch ;
        }
        if(lastCh != ' ')
            MAP[i][num - 1] = 1 ;

    }
   
    for(int j = 0; j < locationNum ; j++)
    {
        for(int k = 0; k < locationNum ; k++)
            if(MAP[j][k] != 1)
                MAP[j][k] = 0 ;
    }

    printf("输入的地图是 : \n");
    for(int m = 0; m < locationNum ; m++){
        for(int n = 0; n < locationNum ; n++)
            printf("%d  ", MAP[m][n]);
        printf("\n");
    }

}

/******************************************************
判断当前地区能否染当前的颜色
******************************************************/
int checkMap(int index, SqStack &stack, int color){
    int mark = 1 ; 

    while((mark < index )&& (*(stack.base + mark - 1)) * MAP[mark-1][index-1] != color && color <= 4 )
        mark++;
    return  mark;
}


void Push(SqStack &stack, int e)
{
    if(stack.top-stack.base >= stack.stacksize){
        stack.base = (int *)realloc(stack.base, (stack.stacksize + STACKINREMENT)*sizeof(int));
        stack.top = stack.base + stack.stacksize;
           stack.stacksize = stack.stacksize + STACKINREMENT;
    }
    *stack.top++ = e;

}

int Pop(SqStack &stack)
{
    int e = 0;
    if(stack.top - stack.base <= 0){
        printf("ERROR !");
        exit(1);
    }
    e = *--stack.top ;
    return e;
}

int main()
{
    PaintMap() ;
    return 0 ;
}

2011-04-10 00:36
ebao
Rank: 2
来 自:杭州
等 级:论坛游民
帖 子:33
专家分:66
注 册:2011-3-9
收藏
得分:0 
???代码改色没用??
#include<stdafx.h>
#include<stdlib.h>
#include<math.h>
#include<string.h>
#define INIT_STACK_SIZE 10
#define STACKINREMENT 5
typedef struct{
    int * top;
    int * base;
    int stacksize;
}SqStack;

int checkMap(int , SqStack &, int );
void Push(SqStack &, int);
int Pop(SqStack &);

int MAP[20][20] ;
int locationNum ;
 /*  
int MAP[7][7] = {{0, 1, 1, 1, 1, 1, 0},
    {1 ,0 ,0, 0, 0, 1, 0},
    {1, 0, 0, 1, 1, 0, 0},
    {1, 0, 1, 0, 1, 1, 0},
    {1, 0, 1, 1, 0, 1, 0},
    {1, 1, 0, 1, 1, 0, 0},
    {0, 0, 0, 0, 0, 0, 0}};
*/
void PaintMap()
{
    void GetMap();
    SqStack stack;
    stack.base = (int *)malloc(INIT_STACK_SIZE *sizeof(int));
    stack.top = stack.base;
    stack.stacksize = INIT_STACK_SIZE;
    *stack.top++  = 1;

    int color = 1;   int section = 2;
    int mark = 0;

    GetMap() ; /*要求用户输入地图*/
   
    while ( section<=locationNum)
    {
        while(( color <= 4)&&(section <= locationNum))  
        {
           mark = checkMap(section, stack, color);
              // 若不相邻,或若相邻且不重色,对下一个区域判断。
           if (mark < section)   color = color + 1; //相邻且重色
           else
           {
               Push(stack, color);  section = section + 1;  color = 1;
           }//相邻且不重色
       }
       if(color > 4)
       {
           section = section - 1;   color = Pop(stack) + 1;
       }
    }
   
    printf("染色的结果是  :\n" );
    for(int i = 0; i < locationNum ; i++)
        printf("%d  ", *(stack.base + i));
    printf("\n");
   
}

/*************************************************
要求用户输入地图的有关信息
*************************************************/
void GetMap(){

    printf("需要染色的地区数 : ");
    scanf("%d", &locationNum);
   
    while(getchar() != '\n');

    printf("输入地图 : \n");
    for(int i = 0 ; i < locationNum ; i++)
    {   
        char ch , lastCh ; int num = 0;
        printf("与第 %d 号区域相邻的所有区域号 : " , i + 1);
        while((ch = getchar()) != '\n')
        {   
            if(ch == ' ' ){
                MAP[i][num - 1] = 1 ;
                num = 0;
            }else
                num = num * 10 + (ch - '0') ;
            lastCh = ch ;
        }
        if(lastCh != ' ')
            MAP[i][num - 1] = 1 ;

    }
   
    for(int j = 0; j < locationNum ; j++)
    {
        for(int k = 0; k < locationNum ; k++)
            if(MAP[j][k] != 1)
                MAP[j][k] = 0 ;
    }

    printf("输入的地图是 : \n");
    for(int m = 0; m < locationNum ; m++){
        for(int n = 0; n < locationNum ; n++)
            printf("%d  ", MAP[m][n]);
        printf("\n");
    }

}

/******************************************************
判断当前地区能否染当前的颜色
******************************************************/
int checkMap(int index, SqStack &stack, int color){
    int mark = 1 ;

    while((mark < index )&& (*(stack.base + mark - 1)) * MAP[mark-1][index-1] != color && color <= 4 )
        mark++;
    return  mark;
}


void Push(SqStack &stack, int e)
{
    if(stack.top-stack.base >= stack.stacksize){
        stack.base = (int *)realloc(stack.base, (stack.stacksize + STACKINREMENT)*sizeof(int));
        stack.top = stack.base + stack.stacksize;
           stack.stacksize = stack.stacksize + STACKINREMENT;
    }
    *stack.top++ = e;

}

int Pop(SqStack &stack)
{
    int e = 0;
    if(stack.top - stack.base <= 0){
        printf("ERROR !");
        exit(1);
    }
    e = *--stack.top ;
    return e;
}

int main()
{
    PaintMap() ;
    return 0 ;
}
2011-04-10 00:37
快速回复:求C语言地图四染色代码..
数据加载中...
 
   



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

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