信息学奥赛一本通-编程启蒙3318:练54.1 6084问题

3318:练54.1 6084问题

时间限制: 1000 ms 内存限制: 65536 KB

提交数: 419 通过数: 300

从这里进入题目:信息学奥赛一本通-编程启蒙(C++版)在线评测系统

【题目描述】

任意给出一个四位数,把它重新组成一个四位的最大数和一个最小数,算出两者间的差。

例如:37213721 这个数,可以重组成:73217321 和 12371237,差值为 7321−12377321−1237。

【输入】

一个四位数。

【输出】

题目中所说的差值。

【输入样例】

复制代码
3721

【输出样例】

复制代码
6084

思路:

我想到了一种巧妙的思路

我们首先定义一下long long ls;

这里ls存储的就是输入的数字

我们可以确定ls是四位数,所以我们可以把ls的每一位分离开来(用数组存储):

cpp 复制代码
	long long a[5];
	a[1]=ls/1000;
	a[2]=ls/100%10;
	a[3]=ls/10%10;
	a[4]=ls%10;

这里注意了,重点来了!

我们已经将四个位置上的数存在了数组里,那我们现在只需要对数组里的四个数进行排序(从小到大),然后定义一个变量mi,然后mi=a[1]*1000+a[2]*100+a[3]*10+a[4],mi也就是ls能组成的最小的数字,这样我们就能得到最小的数字,最大的数字也可以用类似的方法得出来

那我们怎么排序呢?

不懂的看这里:sort排序-CSDN博客

如果你知道排序这道题应该很简单吧?


代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
bool cmp(long long a,long long b){
	return a>b;
}
int main(){
	long long ls;
	cin>>ls;
	long long a[5];
	a[1]=ls/1000;
	a[2]=ls/100%10;
	a[3]=ls/10%10;
	a[4]=ls%10;
	sort(a+1,a+5);
	long long mi=a[1]*1000+a[2]*100+a[3]*10+a[4];
	sort(a+1,a+5,cmp);
	long long ma=a[1]*1000+a[2]*100+a[3]*10+a[4];
	ma-=mi;
	cout<<ma;
	return 0;
}
相关推荐
智驱力人工智能33 分钟前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
2301_764441331 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天1 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
priority_key3 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
不染尘.4 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
来荔枝一大筐5 小时前
力扣 寻找两个正序数组的中位数
算法
算法与编程之美5 小时前
理解Java finalize函数
java·开发语言·jvm·算法
地平线开发者6 小时前
LLM 训练基础概念与流程简介
算法·自动驾驶
点云SLAM6 小时前
弱纹理图像特征匹配算法推荐汇总
人工智能·深度学习·算法·计算机视觉·机器人·slam·弱纹理图像特征匹配
星释6 小时前
Rust 练习册 :Matching Brackets与栈数据结构
数据结构·算法·rust