题目:

程序:

  1. #include <stdio.h>
  2.  
  3. int main(void) {
  4. int n, a, b, c, t, A, B;
  5. printf("输入一个三位数整数:");
  6. scanf("%d",&n);
  7. do{
  8. /*a, b, c 分别是百位数,十位数,个位数*/
  9. a = n/;
  10. b = (n%)/;
  11. c = (n%);
  12. /* 百位数,十位数,个位数按照从大到小的顺序重排,以便下一步中求重排后的最大值A和最小值B*/
  13. if(a<b) {
  14. t = a; a = b; b = t;
  15. }
  16. if(a<c) {
  17. t = a; a = c; c = t;
  18. }
  19. if(b<c) {
  20. t = b; b = c; c = t;
  21. }
  22. /*从排后的最大数A与最小数B*/
  23. A = a * + b * + c;
  24. B = c * + b * + a;
  25. /*将最大数与最小数的差,重新赋给变量n,以便做循环判断或下次循环使用*/
  26. n = A - B;
  27. /*输出过程*/
  28. printf("%d - %d = %d\n", A, B, n);
  29. } while(n!= && n!=);
  30. return ;
  31. }

程序说明:

1. 程序大体思路可以看程序中注释,大体分为两个步骤:输入和循环中计算。其中循环中计算过程分为这么几个步骤:求个位十位百位上三个数字;个位十位百位三个数字按从大到小排列;求得重排后的最大值和最小值;求差和输出。

2. 难点在于:(1)求个位十位百位数字;(2)确定循环变量n;(3)黑洞数算法计算过程的程序表达。

3. 关于循环变量n: 因为算法中要求的是重排后数字的最大值与最小值之差。所以n是循环变量。

运行结果:

错误程序:

错误或可优化部分分析:

1. (错误)变量名混用导致棋艺:c和C混用了,难以分清c 和C的具体含义。根据程序理解可能是:(1)个位十位百位三个数字中的一个。(好像小写c是这个意思);(2)重排后的差。(好像大写C是这个意思)。但在while循环判断的时候用错了。

2. (可能是错误)个位十位百位计算过程应该向上移动若干行:这里是否是个错误,主要看你对算法实现的过程,还有就是算法中的循环变量使用的是哪个。

3. (可优化)定义的变量最好不要用double:因为这里要求的数字范围总是整数,并且不超过3位数,所以用 int 类型最方便。用double虽然不算错误,但会在计算过程中转化为int类型,所以用double没必要。在具体程序中根据具体类型选择适当的数据类型即可,不必使用更宽范围的类型。

4. (可优化)求个位、十位、百位数字计算的优化:(假设表达式中用的是重排后的差,下面说明中我改成了大写C)

a = ((int)C/100)%10;    (int)C/100 结果是百位数之前的部分,因为C是三位数,所以(int)C/100结果是百位数。因为C是三位数,虽然这里没错但没必要再进行 %10 求余。

另外就是因为定义C是double类型,实际计算是用int类型,所以这里使用了强制类型转换,反而更麻烦。

18.12.09-C语言练习:黑洞数 / Kaprekar问题的更多相关文章

  1. [CareerCup] 18.12 Largest Sum Submatrix 和最大的子矩阵

    18.12 Given an NxN matrix of positive and negative integers, write code to find the submatrix with t ...

  2. QVM 实操记 - 18.12.28

    视频回放地址:https://i.iamlj.com/mp4/QVM-IMC-12.27-1080P.mp4 目录 目录 常规开发部署流程 准备工作 开发准备 网站部署 操作步骤 重装系统 LANP环 ...

  3. Navicat Premium 12.0.18 / 12.0.24安装与激活

    若使用Navicat Premium 12.1.8.0请转至Navicat Premium 12.1.8.0安装与激活,其实每个小版本更迭变化不大.另外最重要的是,请仔细阅读本文激活部分,总有一些人遇 ...

  4. 尚学python课程---12、python语言介绍

    尚学python课程---12.python语言介绍 一.总结 一句话总结: 1.操作简单:简便计算:允许通过单个“import”语句后跟一个函数调用来完成复杂的计算.虽慢 2.库丰富:比如人工智能和 ...

  5. 2021.12.09 [HEOI2016/TJOI2016]排序(线段树+二分,把一个序列转换为01串)

    2021.12.09 [HEOI2016/TJOI2016]排序(线段树+二分,把一个序列转换为01串) https://www.luogu.com.cn/problem/P2824 题意: 在 20 ...

  6. 统计C语言程序行数

    补充前一篇中统计C语言程序行数的程序 写得比较匆忙,可能有些失误,等弄明白GitHub的用法并完善程序后再补充完整代码链接 没有写成函数,但经过简单修改可以作为一个计算或判断函数使用 判断算法主要为以 ...

  7. C语言函数參数传递原理

    C语言中參数的传递方式一般存在两种方式:一种是通过栈的形式传递.还有一种是通过寄存器的方式传递的. 这次.我们仅仅是具体描写叙述一下第一种參数传递方式,第二种方式在这里不做具体介绍. 首先,我们看一下 ...

  8. 黑洞数--python

    黑洞数:黑洞数又称陷阱数,是类具有奇特转换特性的整数.任何一个数字不全相同整数,经有限“重排求差”操作,总会得某一个或一些数,这些数即为黑洞数.“重排求差”操作即把组成该数的数字重排后得到的最大数减去 ...

  9. 18.12.02-C语言练习:韩信点兵

    C语言练习:韩信点兵 题目说明:本题是中国经典问题,有多种解法,从数论课程角度看,是一个不定方程组,而且答案不唯一. 但这里采用程序解法,使用的是暴力破解.枚举可能的解,然后根据条件判断,满足所有条件 ...

随机推荐

  1. Codeforces 375B Maximum Submatrix 2 (DP)

    <题目链接> 题目大意:给出一个01矩阵,行与行之间可以互换位置,问能够得到最大的全1矩阵的面积. #include <bits/stdc++.h> using namespa ...

  2. C#堆和栈

    一.在讲堆栈之前,我们先看看值类型和引用类型: 1,我们看看值类型与引用类型的存储方式: 引用类型:引用类型存储在堆中.类型实例化的时候,会在堆中开辟一部分空间存储类的实例.类对象的引用还是存储在栈中 ...

  3. loadrunner之java user脚本开发

    脚本开发环境: loadrunner11.0 jdk1.6.32_x86_32 脚本开发 1.选择JavaVuser协议 2.配置java环境(Vuser--RunTime Settings) 3.开 ...

  4. Physics Experiment 弹性碰撞 [POJ3684]

    题意 有一个竖直的管子内有n个小球,小球的半径为r,最下面的小球距离地面h高度,让小球每隔一秒自由下落一个,小球与地面,小球与小球之间可视为弹性碰撞,让求T时间后这些小球的分布 Input The f ...

  5. NOIP-无线网路发射器选址

    题目描述 随着智能手机的日益普及,人们对无线网的需求日益增大.某城市决定对城市内的公共场所覆盖无线网. 假设该城市的布局为由严格平行的129条东西向街道和129条南北向街道所形成的网格状,并且相邻的平 ...

  6. vue学习:安装及创建项目

    1.先安装npm 参考链接:https://www.cnblogs.com/Hao-Killer/p/7235398.html 查看npm版本:在终端输入:npm -v 2.在安装vue # 安装vu ...

  7. EASYUI combobox firefox 下取值为空的问题或不支持中文检索的问题

    输入中文包含数字 或者全部非中文是没问题的,这个是因为火狐浏览器输入中文输入法的时候 只能触发onkeyup而不能触发onkeydown的问题.而easyui渲染后赋值给隐藏input的过程需要 依赖 ...

  8. [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed

    1.在vs编写时出现这个问题(以下为网络查询结果) 问题的原因是“SSL: CERTIFICATE_VERIFY_FAILED”. Python 升级到 2.7.9 之后引入了一个新特性,当使用url ...

  9. Android 一个日历控件的实现代码

    转载  2017-05-19   作者:Othershe   我要评论 本篇文章主要介绍了Android 一个日历控件的实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看 ...

  10. 移动端无法复制:使用clipboard.js碰到的一个小问题

    移动端无法复制:使用clipboard.js碰到的一个小问题   直接看下面的代码:在移动端访问,点击,能正常复制. <html> <head> <meta http-e ...