[题] 求特殊自然数 #十进制转n进制

题目

NOI / 1.5编程基础之循环控制-25:求特殊自然数

题解

首先,不可能无限穷举

范围限定:七进制与九进制表示都是三位数

最大:888(9) = 728(10)

最小:100(7) = 49(10)

然后就是十进制转x进制的问题

n对xa取模,就是对应xa位上的数字,因为模出来的数不足x^a

然后n/=xa;表示n将对x(a+1)进行取模

重复此操作直至n=0。

代码

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
//把n转换为x进制下的数 
int turn(int n, int x) {
	int ans = 0, a1 = 1;
	while(n) {
		ans += (n % x) * a1;
		n /= x; 
		//要进位咯 
		a1 *= 10;
	}
	return ans;
}
int main(){
	int n7, n9;
	for(int i = 49; i <= 728; i ++) {
		n7 = turn(i, 7);
		n9 = turn(i, 9);
		if(n7 / 100 == n9 % 10 && (n7 /10) % 10 == (n9 /10) % 10 && n9 / 100 == n7 % 10) {
			printf("%d\n%d\n%d", i, n7, n9);
			break;
		}
	}
	return 0;
}
相关推荐
xian_wwq1 天前
【学习笔记】多租户的 Agent 隔离设计
笔记·学习
互联网江湖1 天前
腾讯AI的时代之问:姚顺雨是不是另一个张小龙?
笔记
迷途之人不知返1 天前
Stack & Queue
c++·算法
(Charon)1 天前
【C++/Qt】Qt 实现 MQTT 测试工具:连接 Broker、订阅主题与发布消息
开发语言·c++·qt
深蓝海拓1 天前
PySide6,图形按钮使用系统内置图标
笔记·python·学习·pyqt
春蕾夏荷_7282977251 天前
1、c++ acl udp服务器客户端简单实例-服务器端(1)
服务器·c++·udp
誰能久伴不乏1 天前
Qt/C++ 架构之美:用一个“水龙头”隐喻,讲透面向接口编程与彻底解耦
c++·qt·架构
楼田莉子1 天前
Linux网络:数据链路层
linux·服务器·开发语言·网络·c++·后端
chushiyunen1 天前
npy文件笔记
笔记·python
AI进化营-智能译站1 天前
ROS2 C++开发系列01:在ROS2上编写第一个C++ hello word
开发语言·c++·ai·word