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

2023-11-10 16:41

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

来由

今天看到一个红包死活一笔画不出来,然后我用c写个段程序用于解决这个问题

思想

主要采用栈来实现路径的记录与回退,灵感来源于迷宫求解问题

程序使用

  1. 给顶点标上序号
  2. 求出这个图的邻接矩阵
  3. 修改程序中宏定义的MAXSIZE为定点数
  4. 运行,输入邻接矩阵

代码

#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;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;
}
int main()
{int edges[MAXSIZE][MAXSIZE]={0};int i=0,j=0;for(i=1;i<=MAXSIZE;i++){for(j=1;j<=MAXSIZE;j++){scanf("%d",&edges[i-1][j-1]);}}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("该图无法一次走过所有边,无法一笔画");
}

例子

在这里插入图片描述
标序号
在这里插入图片描述

求出邻接矩阵
在这里插入图片描述
运行输入
在这里插入图片描述
得出一笔画顺序

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



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

相关文章

解决mysql插入数据锁等待超时报错:Lock wait timeout exceeded;try restarting transaction

《解决mysql插入数据锁等待超时报错:Lockwaittimeoutexceeded;tryrestartingtransaction》:本文主要介绍解决mysql插入数据锁等待超时报... 目录报错信息解决办法1、数据库中执行如下sql2、再到 INNODB_TRX 事务表中查看总结报错信息Lock

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

Python函数返回多个值的多种方法小结

《Python函数返回多个值的多种方法小结》在Python中,函数通常用于封装一段代码,使其可以重复调用,有时,我们希望一个函数能够返回多个值,Python提供了几种不同的方法来实现这一点,需要的朋友... 目录一、使用元组(Tuple):二、使用列表(list)三、使用字典(Dictionary)四、 使

Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法

《Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法》在Linux系统中,管理磁盘设备和分区是日常运维工作的重要部分,而lsblk命令是一个强大的工具,它用于列出系统中的块设备(blockde... 目录1. 查看所有磁盘的物理信息方法 1:使用 lsblk(推荐)方法 2:使用 fdisk -l(

使用Python获取JS加载的数据的多种实现方法

《使用Python获取JS加载的数据的多种实现方法》在当今的互联网时代,网页数据的动态加载已经成为一种常见的技术手段,许多现代网站通过JavaScript(JS)动态加载内容,这使得传统的静态网页爬取... 目录引言一、动态 网页与js加载数据的原理二、python爬取JS加载数据的方法(一)分析网络请求1

MySQL查看表的最后一个ID的常见方法

《MySQL查看表的最后一个ID的常见方法》在使用MySQL数据库时,我们经常会遇到需要查看表中最后一个id值的场景,无论是为了调试、数据分析还是其他用途,了解如何快速获取最后一个id都是非常实用的技... 目录背景介绍方法一:使用MAX()函数示例代码解释适用场景方法二:按id降序排序并取第一条示例代码解

Python中合并列表(list)的六种方法小结

《Python中合并列表(list)的六种方法小结》本文主要介绍了Python中合并列表(list)的六种方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录一、直接用 + 合并列表二、用 extend() js方法三、用 zip() 函数交叉合并四、用

Java 中的跨域问题解决方法

《Java中的跨域问题解决方法》跨域问题本质上是浏览器的一种安全机制,与Java本身无关,但Java后端开发者需要理解其来源以便正确解决,下面给大家介绍Java中的跨域问题解决方法,感兴趣的朋友一起... 目录1、Java 中跨域问题的来源1.1. 浏览器同源策略(Same-Origin Policy)1.

Java Stream.reduce()方法操作实际案例讲解

《JavaStream.reduce()方法操作实际案例讲解》reduce是JavaStreamAPI中的一个核心操作,用于将流中的元素组合起来产生单个结果,:本文主要介绍JavaStream.... 目录一、reduce的基本概念1. 什么是reduce操作2. reduce方法的三种形式二、reduce

如何解决yum无法安装epel-release的问题

《如何解决yum无法安装epel-release的问题》:本文主要介绍如何解决yum无法安装epel-release的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录yum无法安装epel-release尝试了第一种方法第二种方法(我就是用这种方法解决的)总结yum