zoukankan      html  css  js  c++  java
  • zzuli oj 1109 数根

    题意分析:
    输入一个正整数,输出该数的数根。数根可以通过把一个数的各个位上的数字加起来得到。如果得到的数是一位数,那么这个数就是数根。如果结果是两位数或者包括更多位的数字,那么再把这些数字加起来。如此进行下去,直到得到是一位数为止。比如,对于24来说,把2和4相加得到6,由于6是一位数,因此6是24的数根。再比如39,把3和9加起来得到12,由于12不是一位数,因此还得把1和2加起来,最后得到3,这是一个一位数,因此3是39的数根。
    要求使用函数,定义函数digitSum(int n)求n的各位数字和,其余功能在main()函数中实现。
    int digitSum(int n)
    {
    //函数返回n的各位数字之和
    }
    解题思路:
    先编写函数求出正整数的各位数字之和,判断该数是否为一位数字,如果是一位数字结束,相反连续使用函数直至sum为一位数字,输出该和即为原n的数根。
    代码实现:

     1 #include<stdio.h>
     2 int digitSum(int n)
     3 {
     4     int sum=0;
     5     while(n!=0)
     6     {
     7         sum+=n%10;
     8         n=n/10;
     9     }
    10     return sum;
    11 }
    12 int main()
    13 {
    14     int n,sum;
    15     scanf("%d",&n);
    16     sum=digitSum(n);
    17     while(sum>10)
    18         {
    19             sum=digitSum(sum);
    20         }
    21     printf("%d",sum);
    22     return 0;
    23 }


    易错分析:
    求各位数字之和是之前的套路,这道题目的关键点在于控制循环直到sum也就是数根为个位数字,主要想法就是先把计算出来的的第一个sum判断是否为个位数字,如果是不进入循环
    直接输出,如果不是进入循环,反复计算直至为个位数字,输出。

  • 相关阅读:
    数学形态学——腐蚀、膨胀、开、闭、细化
    VS2010中 报错:error C2146、error C4430 原因一:缺少CvvImage类
    帧同步和状态同步
    HTML5触摸事件演化tap事件
    screenX clientX pageX的区别
    phaser的小游戏的onInputDown问题
    phaser入手
    pixi.js 微信小游戏 入手
    正则表达式
    剖析Vue原理&实现双向绑定MVVM-2
  • 原文地址:https://www.cnblogs.com/yuanqingwen/p/10356254.html
Copyright © 2011-2022 走看看