qq一笔画红包 的c语言解决方法(改)

2023-11-10 16:41

本文主要是介绍qq一笔画红包 的c语言解决方法(改),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我之前的程序采用邻接矩阵存储图链接如下,我这里稍作改进

https://blog.csdn.net/eu_zero/article/details/112056006

考虑到稀疏图用类似于邻接表的方式来输入可以节约用户的输入时间,于是我改进了代码,新增一个in()函数采用类似邻接表的录入形式,内部存储形式不变依旧用邻接矩阵存储图。

顺手修复了对于边数较少的图无法实现一笔画的bug

#include <stdio.h>
//节点从1开始编号
#define MAXSIZE 20
typedef struct edgeStack
{int from;int to;
}Edge;Edge VisitStack[100]={0};
Edge PathStack[100]={0};
int VTop=-1,PTop=-1,SumEdges=0;void Invisit(int from,int to)
{VTop++;VisitStack[VTop].from=from;VisitStack[VTop].to=to;
}
void Inpath(int from,int to)
{PTop++;PathStack[PTop].from=from;PathStack[PTop].to=to;
}
void Outvisit()
{VTop--;
}
void Outpath()
{PTop--;
}
int Visit(int from,int to) //边未走过则返回1
{int i=0;for(i=0;i<=VTop;i++){if(VisitStack[i].from==from && VisitStack[i].to==to) return 0;if(VisitStack[i].from==to && VisitStack[i].to==from) return 0;}return 1;
}
void find(int edges[][MAXSIZE],int v)
{int i=v,j=0;for(j=1;j<=MAXSIZE;j++){if(Visit(i,j)&&edges[i-1][j-1]==1)     //判断是否走过这条边并且是否有边存在{Invisit(i,j);Inpath(i,j);printf("%d ",i);find(edges,j); //递归访问下一个节点}}if((PTop+1<SumEdges)&&(j>MAXSIZE)) Outpath();
}
int search(int edges[][MAXSIZE])
{int i=0,j=0;for(i=0;i<MAXSIZE;i++){for(j=0;j<MAXSIZE;j++){SumEdges+=edges[i][j];}}SumEdges=SumEdges/2;  //求出总边数,用于之后判断是否遍历完成for(i=1;i<=MAXSIZE;i++){VTop=-1;  //换第一个节点的时候需要清零栈PTop=-1;printf("以%d为第一个点: ",i);find(edges,i);printf("\n");if(PTop+1>=SumEdges) return 1;}return 0;
}
void in(int edges[][MAXSIZE],int v)
{char ch=0;int num=0,i=0,j=0;int a[MAXSIZE]={0};while((ch=getchar())!='\n'){if( ch<='9' && ch>='0'){num=num*10+(ch-'0');}else if(ch=' '){a[i++]=num;num=0;}}if(num==0) return;  //如果该点没有邻接点,避免对邻接数组的改动a[i]=num;for(j=0;j<=i;j++){edges[v-1][a[j]-1]=1;}printf("邻接矩阵更新为:\n");for(i=1;i<=MAXSIZE;i++){for(j=1;j<=MAXSIZE;j++){printf("%d ",edges[i-1][j-1]);}printf("\n");}
}
int main()
{int edges[MAXSIZE][MAXSIZE]={0};int i=0,j=0;printf("请一次输入与每一个顶点邻接的顶点编号,空格隔开,回车结束\n");for(i=1;i<=MAXSIZE;i++){printf("与%d点邻接的顶点序列:",i);in(edges,i);}if(search(edges)){printf("\n成功完成一笔画,一种解法为: ");printf("%d ",PathStack[0].from);for(i=0;i<=PTop;i++){printf("%d ",PathStack[i].to);}printf("\n");}else printf("该图无法一次走过所有边,无法一笔画\n");
}

在这里插入图片描述

在这里插入图片描述

这篇关于qq一笔画红包 的c语言解决方法(改)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/383961

相关文章

检查 Nginx 是否启动的几种方法

《检查Nginx是否启动的几种方法》本文主要介绍了检查Nginx是否启动的几种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1. 使用 systemctl 命令(推荐)2. 使用 service 命令3. 检查进程是否存在4

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

springboot中配置logback-spring.xml的方法

《springboot中配置logback-spring.xml的方法》文章介绍了如何在SpringBoot项目中配置logback-spring.xml文件来进行日志管理,包括如何定义日志输出方式、... 目录一、在src/main/resources目录下,也就是在classpath路径下创建logba

解决idea启动项目报错java: OutOfMemoryError: insufficient memory

《解决idea启动项目报错java:OutOfMemoryError:insufficientmemory》:本文主要介绍解决idea启动项目报错java:OutOfMemoryError... 目录原因:解决:总结 原因:在Java中遇到OutOfMemoryError: insufficient me

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

maven异常Invalid bound statement(not found)的问题解决

《maven异常Invalidboundstatement(notfound)的问题解决》本文详细介绍了Maven项目中常见的Invalidboundstatement异常及其解决方案,文中通过... 目录Maven异常:Invalid bound statement (not found) 详解问题描述可

C++打印 vector的几种方法小结

《C++打印vector的几种方法小结》本文介绍了C++中遍历vector的几种方法,包括使用迭代器、auto关键字、typedef、计数器以及C++11引入的范围基础循环,具有一定的参考价值,感兴... 目录1. 使用迭代器2. 使用 auto (C++11) / typedef / type alias