python求黑洞数_求解黑洞数

article/2025/9/9 15:03:14

问题描写:

黑洞数又称圈套数,是类具有奇特转换特性的整数。任何1个数字不全相同的整数,

经有限“重排求差”操作,总会得到某1个或1些数,这些数即为黑洞数。

“重排求差”操作即把组成该数的数字重排后得到的最大数减去重排后得到的最小数。

举个例子,3位数的黑洞数为495.

简易推导进程:随意找个数,如297,3个位上的数从小到大和从大到小各排1次,

为972和279,相减得693。按上面做法再做1次,得到594,再做1次,得到495,

以后反复都得到495。

验证4位数的黑洞数为6174。解题思路:

ab7161fbc2bdc9ee55de09e1763730dc.png

#include

#include

#include

using namespace std;

#define LENTH 100

/* 降序:冒泡排序 */

void dec_sort(int array[],int n)

{

int flag = 0;

for(int i=0;i

{

for(int j=0;j

{

if(array[j] < array[j+1])

{

array[j] += array[j+1];//array[j] = array[j] + array[j+1]

array[j+1] = array[j] - array[j+1];

array[j] -= array[j+1];//array[j] = array[j] - array[j+1]

flag = 1;

}

}

if(flag == 0)//在1趟排序中若未产生交换,表明已排序好,退出程序

break;

}

}

/* 升序:选择排序 */

void inc_sort(int array[],int n)

{

int k;

for(int i=0;i

{

k = i;//假定要排序的1组数据中第1个数最小(k寄存待排序数据中最小值的下标)

for(int j=k+1;j

{

if(array[j] < array[k])//若存在比当前值还小的数,则交换下标

{

k = j;

}

}

if(k != i)

{

array[i] += array[k];

array[k] = array[i] - array[k];

array[i] -= array[k];

}

}

}

int black_hole_num(int n)

{

cout<

//注意:!!!求解进程中会改变n的值,而下面要用到n,不想它改变

//所以用临时变量保存他的值,改变临时变量,而不改变它

int temp = n;

int array[LENTH];

int i = 0;

int count;

int max = 0;

int min = 0;

/* 将该数值的各个位寄存在数组中 */

while(temp)

{

array[i] = temp%10;

i++;

temp /= 10;

}

count = i;

/* 元素升序以后,求解最小值*/

inc_sort(array,count);

for(i=0;i

{

min = min*10 + array[i];

}

/* 元素降序以后,求解最大值*/

dec_sort(array,count);

for(i=0;i

{

max = max*10 + array[i];

}

/*if(max - min == n)//此处要用到n的值,所以改变临时变量而不改变n

return n;

else

return black_hole_num(max - min);*/

return (max - min == n) ? n:black_hole_num(max - min);

}

int main()

{

int flag = 1;

int n;

int num;

system("mode con cols=100 lines=100");

system("color 0A");

while(flag)

{

cout<

cout<

cout<

cin>>n;

cout<

cin>>num;

cout<

cout<

cin>>flag;

}

return 0;

}

193fa14ff4d74b33dbf2ead5be065909.png

当输入5的时候,会堕入[82962,75933,63954,61974]循环圈中

fca08f20834be59ba85bc071015b6dd1.png

任何1个数字不全相同的整数,

经有限“重排求差”操作,总会得到某1个或1些数,这些数即为黑洞数。


http://chatgpt.dhexx.cn/article/LXGHIC0c.shtml

相关文章

负载均衡之加权轮询算法

在介绍加权轮询算法(WeightedRound-Robin)之前&#xff0c;首先介绍一下轮询算法(Round-Robin)。 一&#xff1a;轮询算法(Round-Robin) 轮询算法是最简单的一种负载均衡算法。它的原理是把来自用户的请求轮流分配给内部的服务器&#xff1a;从服务器1开始&#xff0c;直到服务…

基于HTTP的长轮询实现

Web客户端与服务器之间基于Ajax&#xff08;http&#xff09;的常用通信方式&#xff0c;分为短连接与长轮询。 短连接&#xff1a;客户端和服务器每进行一次HTTP操作&#xff0c;就建立一次连接&#xff0c;任务结束就中断连接。 在长轮询机制中&#xff0c;客户端像传统轮询一…

Linux轮询操作

Linux设备之非阻塞I/O操作 文章目录 Linux设备之非阻塞I/O操作前言一、接口简介1、select2、poll3、epoll4、总结 二、接口介绍三、代码样例 前言 上一篇讲解了Linux设备的阻塞I/O操作&#xff0c;其原理是利用了把进程挂到等待队列中&#xff0c;等条件满足时再唤醒此进程。本…

短轮询和长轮询

轮询是由客户端每隔一段时间向服务器发出HTTP请求&#xff0c;服务端接收到请求后向客户端返回最新的数据。 客户端的轮询方式一般分为短轮询和长轮询。 短轮询&#xff1a; 一般是由客户端每隔一段时间向服务器发起一次普通HTTP请求。服务端查询当前接口是否有数据更新&#x…

轮询与长轮询

轮询&#xff1a;说白了就是客户端定时去请求服务端&#xff0c; 是客户端主动请求来促使数据更新&#xff1b; 长轮询&#xff1a;说白了 也是客户端请求服务端&#xff0c;但是服务端并不是即时返回&#xff0c;而是当有内容更新的时候才返回内容给客户端&#xff0c;从流程…

前端实现轮询

方法一&#xff1a;简单实现 componentDidMount() {this.props.countFxMissionByStatus();countSwiftMessage(); }componentWillReceiveProps(nextProps) {const {location} nextProps;// 判断页面然后在更新的周期中实现轮询const isSwiftManage location.pathname.indexOf…

NGINX轮询机制的几种形式

前言&#xff1a;总以为轮询就简单的next而已&#xff0c;实际还有几种不同的实现机制。某个客户的源站有几个不同的IP&#xff0c;回源的时候自然是采用的轮询的机制。客户业务上线前&#xff0c;检查源站的联通性发现一个漏网之鱼竟然差点滥竽充数。然而客户的想法确是&#…

事件轮询机制理解

进程与线程 首先简单了解下进程和线程的概念 进程&#xff1a;cpu资源分配的最小的单位&#xff0c;是拥有资源和独立运行的最小单位&#xff0c;程序执行时&#xff0c;会创建一个进程&#xff0c;cpu为其分配资源&#xff0c;并加入进程就绪队列。线程&#xff1a;cpu调度的…

事件轮询机制

事件循环(轮询)机制 js是单线程的所有js代码都是在主线程执行的同步任务进入主线程即会执行异步任务则会进入浏览器的管理模块 (有DOM事件管理模块、ajax请求管理模块、定时器管理模块等)管理模块一直监视异步任务是否满足条件。如果满足条件则会将对应的回调放入回调队列中(c…

IP多播(组播)

一 IP多播的基本概念 IP多播(multicast&#xff0c;也被译为组播)&#xff0c;它是一种一对多的通信方式。与单播相比&#xff0c;多播可以大大节约网络资源。 以视频流媒体服务为例说明单播和多播的区别&#xff0c;如图所示&#xff1a; 图1 单播与多播的比较 (a) 中使用的…

多播

19.1 概述 单播地址标识单个接口&#xff0c;广播地址标识子网上的所有接口&#xff0c;多播地址标识一组接口。单播和广播是编制方案的两个极端(要么一个要么全部)&#xff0c;多播的目的就在于提供一种折衷方案。多播数据报仅由对该数据报感兴趣的接口接收&#xff0c;也就是…

单播 、多播(组播)、广播

作者&#xff1a;yhthu 链接&#xff1a;https://www.jianshu.com/p/cc62e070a6d2#comments 来源&#xff1a;简书 著作权归作者所有。商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处。 目录 单播、多播(组播)、广播、任播单播组播广播任播 单播、多播(组播)、广…

UDP之多播/组播

目录 一.什么是多播(组播)&#xff1f;为什么出现多播(组播)&#xff1f;二.组播地址三.主机网卡对应的编号 ifconfig命令ip ad (ip adress)获取网卡对应的编号四.多播实现 一.什么是多播(组播)&#xff1f;为什么出现多播(组播)&#xff1f; 由上节课讲到的广播&#xff0c;可…

单播、多播和广播经典详解

1 什么是单播、多播和广播 “单播”&#xff08;Unicast&#xff09;、“多播”&#xff08;Multicast&#xff09;和“广播”&#xff08;Broadcast&#xff09;这三个术语都是用来描述网络节点之间通讯方式的术语。那么这些术语究竟是什么意思&#xff1f;区别何在…

多播--概念和编程

11.3 多播 单播用于两个主机之间的端对端通信&#xff0c;广播用于一个主机对整个局域网上所有主机上的数据通信。单播和广播是两个极端&#xff0c;要么对一个主机进行通信&#xff0c;要么对整个局域网上的主机进行通信。实际情况下&#xff0c;经常需要对一组特定的主机进…

单播、多播(主播)、广播简介

单播 简介 单播&#xff08;unicast&#xff09;是指封包在计算机网络的传输中&#xff0c;目的地址为单一目标的一种传输方式。每次只有两个实体相互通信&#xff0c;发送端和接收端都是唯一确定的。它是现今网络应用最为广泛&#xff0c;通常所使用的网络协议或服务大多采用…

IP多播

部分转载自&#xff1a;http://www.firewall.cx/networking-topics/general-networking/107-network-multicast.html 剩下的基本参考谢希仁计算机网络7th 1. 基本概念 IP多播直观上可以按照下图理解&#xff0c;源主机只需要发送一份数据&#xff0c;而网络中的路由器在转发…

多播(组播)、单播、任播和广播

定义 单播(unicast): 是指封包在计算机网络的传输中&#xff0c;目的地址为单一目标的一种传输方式。它是现今网络应用最为广泛&#xff0c;通常所使用的网络协议或服务大多采用单播传输&#xff0c;例如一切基于TCP的协议。组播(multicast): 也叫多播&#xff0c; 多点广播或…

IP多播(计算机网络-网络层)

目录 一对多通信的应用需求 单播 vs 多播 多播路由器&#xff08;Multicast Router&#xff09; IP 多播的一些特点 D 类 IP 地址与以太网多播地址的映射关系 IP多播需要两种协议 互联网组管理协议 IGMP 多播路由选择协议 两种多播路由选择方法 建议的IP多播路由选择协…

组播,多播

组播&#xff0c;多播&#xff1a;当网络中进行了组播网部署后&#xff0c;一个台设备仅需要基于一个流量进行一次封装及可将该流量转发到所有的组员处&#xff0c;这些组员可处在网络的任何位置&#xff1b;对非组员不产生影响。再未进行组播网络部署的环境下&#xff0c;以组…