快乐数 C++题解

本文是一篇编程问题描述,要求实现一个算法来判断一个正整数是否为快乐数,即其经过每次将每个位置数字平方和后不断迭代,最终是否能变为1。给出C++代码示例并提供测试用例。
摘要由CSDN通过智能技术生成

快乐数

内存限制: 256 MiB 时间限制: 1000 ms 标准输入输出 题目类型: 传统 评测方式: 文本比较

题目描述

题目描述

「快乐数」 定义为:

  • 对于一个正整数,每一次将该数替换为它每个位置上的数字的平方和。
  • 然后重复这个过程直到这个数变为 1,也可能是 无限循环 但始终变不到 1。
  • 如果这个过程 结果为 1,那么这个数就是快乐数。

如果 n 是 快乐数 就输出yes;不是,则返回 no 。

输入格式

第一行输入一个整数 n,表示要判断的数字。

输出格式

如果 n 是 快乐数 就输出yes;不是,则返回 no

样例
样例输入1
复制19
样例输出1
复制yes
样例输入2
复制2
样例输出2
复制no
数据范围

1 <= n <= 2 ^ 31 - 1

#include <bits/stdc++.h>
using namespace std;
int n, slow, fast;
int next(int txt) {
	int sum = 0;
	while(txt != 0) {
		int t = txt % 10;
		sum += t * t;
		txt /= 10;
	} 
	return sum;
} 
int main() {
	scanf("%d", &n);
	slow = n, fast = next(n);
	while(slow != 1 && slow != fast) {
		slow = next(slow);
		fast = next(next(fast));
	} 
	if(slow == 1) {
		printf("yes");
	} else {
		printf("no");
	} 
	return 0;
} 

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值