东方博宜 1450. 数字之和为x的整数

博客围绕东方博宜1450题“数字之和为x的整数”展开,介绍了解题思路。包括按要求用两种方式读入两排数并存储到数组,遍历数组进行拆位运算,将符合条件的数存到新数组,还提到使用sort排序函数对新数组排序,同时分享了编码中踩的坑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

东方博宜 1450. 数字之和为x的整数
这道题踩的坑也是比较多的啊。。。
思路:
1 读入两排数,这里我想严格按照要求来,所以用到了两种输出方式。
2 将读取的数存放到数组中,这里我之前犯了一个错,我定义了一个数组a[10005] ,然后又定义了一个整数a,我以为他们两个是不一样的,但是后面报错了。定义了一个数组a[10005] 后, 当后面再出现a,指的也是这个数组。
3 遍历数组中的每个数,并对每个数进行拆位运算,这里的while循环我用了很多次了,要注意,这里新定义了一个变量m来存每个遍历的数,m是等于a[i] 的,我总是让m=i ,就报错了。
4 符合条件的数存到新的数组d中去。
5新学了sort排序函数,在头文件里面。sort(d,d+j) 表示给谁排序,排序的长度写的 d 的个数 j 。
在这里插入图片描述

#include<iostream>
#include<cstdio> // scanf 在的头文件 
#include<algorithm> //  sort排序函数在的头文件 
using namespace std;
int main()
{
	int x , n ;
	scanf("%d  %d \n" , &x , &n) ; //这是为了满足题意,输入两个数就换行 
	int  a[10005] ; // 定义的数组比要输入的数大一些 
	for(int i = 0 ; i < n ; i++)
	{
		cin >> a[i] ; // 读入要判断的数 
	}
	int cnt , zsum ;
	cnt = 0 ;
	zsum = 0 ;
	int d[10005];
	int j ;
	j = 0 ;
	for(int i = 0 ; i < n ; i++)
	{
		int m , q ,sum ;
		m = a[i] ;
		sum = 0 ;
		while(m > 0) // 对每个数挨个遍历,求和 
		{
			q = m % 10 ;
			sum += q ;
			m = m / 10 ;	
		}
		if(sum == x)
		{
			cnt += 1;
			zsum += a[i] ;
			d[j] = a[i] ; //将符合条件的数存到新的数组中 
			j++;
			
		}
		
		
	}
	cout << zsum << " "<< cnt << endl ;
	sort(d,d+j); //c++中的排序函数,d指的是数组,j指的是数组的个数 
	for(int i = 0 ; i < j ; i++)
	{
		cout << d[i] << " ";
	}
	
	return 0 ;
}
### 关于东方 OJ 平台上的编号为 1862 的题目 '友好数' 对于东方 OJ 上编号为 1862 的题目 “友好数”,虽然具体题干未直接提及,但从相似类型的编程竞赛题目来看,“友好数”的定义通常涉及数论中的某些特性。这类问题往往考察的是两个整数之间的关系或者性质。 #### 定义与背景 一般而言,在数论领域中,“友好对”指的是两正整数 \(a\) 和 \(b\) ,满足条件 \(\frac{\sigma(a)}{a}=\frac{\sigma(b)}{b}\),其中 \(\sigma(x)\) 表示所有能被 \(x\) 整除的自然数之和(含\(x\)本身)。然而针对此特定编号下的“友好数”,可能是指具有某种特殊关联性的单个或一组数字[^1]。 #### 解决方案概述 解决此类问题的关键在于: - **预处理**:提前计算并存储必要的数值信息以便快速查询。 - **优化查找逻辑**:设计高效的算法来匹配符合条件的数字组合,减少不必要的重复运算。 考虑到该类问题的特点,可以采用如下策略实现解决方案: ```cpp #include <iostream> #include <vector> using namespace std; // 计算因子和函数 int sumOfDivisors(int n){ int sum = 1; // 初始化为1因为任何大于1的n至少有因数1 for (int i=2;i*i<=n;++i){ if(n % i == 0){ sum += i; if(i * i != n){ // 如果不是完全平方根,则加上对应的另一个因子 sum += n / i; } } } return sum; } bool isFriendlyNumber(int num, vector<int>& friendlyNumbers){ double ratio = static_cast<double>(sumOfDivisors(num)) / num; for(auto& fn : friendlyNumbers){ if(static_cast<double>(sumOfDivisors(fn))/fn == ratio && fn!=num){ return true; } } return false; } ``` 上述代码片段展示了如何判断一个给定的 `num` 是否属于已知的好友列表 `friendlyNumbers` 中的一员。通过比较各自的比例值来进行判定。 #### 进一步探索方向 为了更深入地理解和解决问题,建议关注以下几个方面: - 掌握更多有关数论的基础概念及其应用; - 学习其他类似的经典案例,积累经验; - 尝试不同的数据结构和技术手段提高效率;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值