#UVa:10591-Happy Number

灆洢 2015-11-29 22:18:50

照著題目將數字的各個位數平方之總和求出,若遇到之前已經求過的數字就知道是Unhappy,若能夠到1那就是Happy。

C++(0.000)

/*******************************************************/
/* UVa 10591 Happy Number                              */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2015/11/29                                 */
/*******************************************************/
#include <iostream>
#include <cstdio>
#include <set>
using namespace std;

int squareSum(int n){
  int sum = 0;
  while( n > 0 ){
    sum += (n % 10) * (n % 10);
    n /= 10;
  }

  return sum;
}

int main(){
  int n;
  while( scanf("%d", &n) != EOF ){
    for( int caseCount = 1 ; caseCount <= n ; ++caseCount ){
      int N;
      scanf("%d", &N);

      set<int> checked;
      checked.insert(N);

      bool isHappy = true;
      int number = N;
      while( number != 1 ){
        number = squareSum(number);
        if( checked.find(number) != checked.end() ){
          isHappy = false;
          break;
        }
        checked.insert(number);
      }

      if( isHappy ){
        printf("Case #%d: %d is a Happy number.\n", caseCount, N);
      }
      else {
        printf("Case #%d: %d is an Unhappy number.\n", caseCount, N);
      }
    }
  }
  return 0;
}

發表迴響

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料