首页 > 其他分享 >洛谷题解 - B3850 [GESP202306 四级] 幸运数

洛谷题解 - B3850 [GESP202306 四级] 幸运数

时间:2024-03-15 18:58:46浏览次数:23  
标签:洛谷 GESP202306 结果 int 题解 样例 76344 16347 正整数

目录

题目描述

小明发明了一种 “幸运数”。一个正整数,其偶数位不变(个位为第 1 1 1 位,十位为第 2 2 2 位,以此类推),奇数位做如下变换:将数字乘以 7 7 7,如果不大于 9 9 9 则作为变换结果,否则把结果的各位数相加,如果结果不大于 9 9 9 则作为变换结果,否则(结果仍大于 9 9 9)继续把各位数相加,直到结果不大于 9 9 9,作为变换结果。变换结束后,把变换结果的各位数相加,如果得到的和是 8 8 8 的倍数,则称一开始的正整数为幸运数。

例如, 16347 16347 16347:第 1 1 1 位为 7 7 7,乘以 7 7 7 结果为 49 49 49,大于 9 9 9,各位数相加为 13 13 13,仍大于 9 9 9,继续各位数相加,最后结果为 4 4 4;第 3 3 3 位为 3 3 3,变换结果为 3 3 3;第 5 5 5 位为 1 1 1,变换结果为 7 7 7。最后变化结果为 76344 76344 76344,对于结果 76344 76344 76344 其各位数之和为 24 24 24,是 8 8 8 的倍数。因此 16347 16347 16347 是幸运数。

输入格式

输入第一行为正整数 N N N,表示有 N N N 个待判断的正整数。约定 1 ≤ N ≤ 20 1 \le N \le 20 1≤N≤20。

从第 2 2 2 行开始的 N N N 行,每行一个正整数,为待判断的正整数。约定这些正整数小于 1 0 12 10^{12} 1012。

输出格式

输出 N N N 行,对应 N N N 个正整数是否为幸运数,如是则输出 ‘T’,否则输出 ‘F’。

提示:不需要等到所有输入结束在依次输出,可以输入一个数就判断一个数并输出,再输入下一个数。

样例 #1

样例输入 #1

2
16347
76344

样例输出 #1

T
F

代码

#include <bits/stdc++.h>
using namespace std;
int a[20];
int trans(int x)
{
	x*=7;
	while(x>9)
	{
		x=x/10+x%10;
	}
	return x;
}
int main()
{
	int n;
	cin>>n;
	while(n--)
	{
		long long x;
		cin>>x;
		int cnt=0;
		while(x>0)
		{
			a[++cnt]=x%10;
			x/=10;
		}
		for(int i=1; i<=cnt; i++)
		{
			if(i%2)
			{
				a[i]=trans(a[i]);
			}
		}
		long long sum=0;
		for(int i=cnt; i>=1; i--)
		{
			sum=sum+a[i];
		}
		cout<<((sum%8==0)?"T":"F")<<endl;
	}
	return 0;
}

标签:洛谷,GESP202306,结果,int,题解,样例,76344,16347,正整数
From: https://blog.csdn.net/Python_enjoy/article/details/136689260

相关文章

  • 炸弹题解
    这题有两种做法,一种tarjan,一种逆天DP用lower_bound或upper查找i所在范围的左右边界对应下标普通Tarjan+缩点#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;constintN=5e5+10,mod=1e9+7;intn,dfn[N],low[N],head2[N],num,cnt,head[N],belong[N];b......
  • 【PR #12】划分序列 / Yet Another Mex Problem 题解
    题目链接题目大意给定一个长度为\(n\)的序列\(a\),定义一段区间的价值为该区间的\(\operatorname{mex}\)乘上区间元素总和。你需要将序列划分成若干个长度\(\leqk\)的区间。一个划分方案的价值为划分出来的每个区间价值之和,求所有划分方案的价值最大值。\(1\leqk\le......
  • centos6使用yum网络源失败,问题解决
    在进行测试环境部署时,需要用到yum安装一些软件包,目前服务器是通外网的,所以这里我就直接使用的网络源进行yum下载的令我惊讶的是用yum命令安装居然失败了!!!以下是我的排查到解决的心路历程:1.首先执行命令yumlist查看发现报错如下:从报错信息来看是说无法连接到http(s),ftp的......
  • 洛谷题单指南-二叉树-P1030 [NOIP2001 普及组] 求先序排列
    原题链接:https://www.luogu.com.cn/problem/P1030题意解读:已知中序、后序,求先序。解题思路:与洛谷题单指南-二叉树-P1827[USACO3.4]美国血统AmericanHeritage非常类似,不在介绍过程,直接给出代码。100分代码:#include<bits/stdc++.h>usingnamespacestd;stringin,post......
  • CF575H Bots 题解 组合数学
    Bots传送门SashaandIraaretwobestfriends.Buttheyaren’tjustfriends,theyaresoftwareengineersandexpertsinartificialintelligence.Theyaredevelopinganalgorithmfortwobotsplayingatwo-playergame.Thegameiscooperativeandturn......
  • 常见问题解决 --- idea与maven使用常识
    1.拿到项目代码后先要知道使用了哪些技术和工具。比如使用的是idea、eclipse还是maven创建的项目,使用什么编程语言,使用什么项目目录结构等等2.如何用maven创建的项目必然有pom.xml,每次修改pom文件后必须重新加载。3.如果修改代码后还是报错,尝试使用clean清除编译缓存再同步maven......
  • 洛谷 P5018 对称二叉树
    题目背景NOIP2018普及组T4题目描述一棵有点权的有根树如果满足以下条件,则被轩轩称为对称二叉树:二叉树;将这棵树所有节点的左右子树交换,新树和原树对应位置的结构相同且点权相等。下图中节点内的数字为权值,节点外的 idid 表示节点编号。现在给出一棵二叉树,希望你找出......
  • 洛谷 B3625 迷宫寻路
    本道题需要注意:如果孩子的起始位置就是‘#’,那孩子就无路可走,出不来了。所以需要特判一下,代码如下:(这是废话,不需要特判,注意题目要求)if(ch[1][1]=='#'){ printf("No\n"); }注意边界条件:if(nx<1||nx>n||ny<1||ny>m){ continue; } if(vis[nx][ny]==1){ cont......
  • Luna likes Love 题解
    ProblemLink简要题意题目很清楚。分析定理两个人中左边的人一直向右运动,和两人向中间走所用的步数相同证明假设有两组人为\(a_l,a_r,b_l,b_r(a_l<a_r,b_l<b_r)\)。\(\textrm{I}.\)当\(a_r<b_l\)(两者互不相交)时如图:显然成立。$\textrm{II}.$......
  • abc155F题解
    abc155F题意:给定\(n\)个灯泡的位置\(a_i\)和状态\(b_i(0/1)\)。给定\(m\)个开关控制区间\([l_i,r_i]\)中所有的灯泡,即使用这个开关会使\([l_i,r_i]\)中所有的灯泡的状态都取反。问能否使这\(n\)个灯泡的状态都变成\(0\),如果可以,输出一种方案,否则,输出\(-1\)。思路:神仙转化题。......