[题] 求特殊自然数 #十进制转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;
}
相关推荐
十五年专注C++开发24 分钟前
QT 中的元对象系统(五):QMetaObject::invokeMethod的使用和实现原理
开发语言·数据结构·c++·qt·设计模式
熬夜学编程的小王28 分钟前
【C++初阶篇】C++中c_str函数的全面解析
c语言·c++·c_str
一线灵44 分钟前
跨平台游戏引擎 axmol-2.5.0 发布
c++·游戏引擎·wasm·axmol
渴望脱下狼皮的羊1 小时前
C++基础讲解
开发语言·c++·后端
同勉共进5 小时前
虚函数表里有什么?(二)——普通单继承下的虚函数表
c++·单继承·虚函数表·dynamic_cast·rtii
郭涤生6 小时前
Chapter 11: Stream Processing_《Designing Data-Intensive Application》
笔记·分布式
永恒迷星.by7 小时前
文件操作(c语言)
c语言·c++·算法·文件操作
Zhichao_979 小时前
【UE5 C++课程系列笔记】32——读Json文件并解析
c++·ue5
点云SLAM9 小时前
C++20新增内容
c++·算法·c++20·c++ 标准库
照书抄代码10 小时前
C++11可变参数模板单例模式
开发语言·c++·单例模式·c++11