素数环问题

问题链接https://www.nowcoder.com/questionTerminal/4437f37768eb45fe9b79d88db47ff32a?orderByHotValue=1&mutiTagIds=656&page=1&onlyReference=false

本文参考了问题链接中答案

问题描述

一个环由n个圈组成,将自然数1-n放入圈内,使得任意相邻圈的两个数之和均为素数。第一个圈的元素均为1。下图为n=6时的一个例子:
在这里插入图片描述

程序样例

输入为一个整数n

  • 6
  • 8

输出分别为

  • 1 4 3 2 5 6
    1 6 5 2 3 4

  • 1 2 3 8 5 6 7 4
    1 2 5 8 3 4 7 6
    1 4 7 6 5 8 3 2
    1 6 7 4 3 8 5 2

解题思路: 栈的回溯调用,深度优先遍历(deep-first search)

当n为奇数时素数环不存在

  • 证明:n为奇数时必然有偶数个奇数,排列成环时必然有两个奇数相邻,两个相邻的奇数相加就是偶数,偶数肯定不是素数。所以当n为奇数时素数环不存在。

以n=4为例:

  • 栈的变化如下:
    在这里插入图片描述
    在这里插入图片描述

  • 遍历的图如下:
    在这里插入图片描述

算法实现

程序只适用n比较小的情况,如果n比较大,栈的递归调用深度过深,会导致栈溢出。此时需要自己定义一个栈来实现,而不该使用函数的栈递归调用。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>

static unsigned int n;
static unsigned int *visited, *result;


// isprime function judge num whether is prime.
// please refer to https://blog.csdn.net/qq_36963214/article/details/90490364
unsigned int isprime(unsigned int num)
{
   
	unsigned int i, half
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值