当前位置: 首页 > news >正文

【C语言】拆数字组成最大数

相信你是最棒哒!!!

文章目录

题目描述

正确代码

法一注释版

简洁版

法二注释版

简洁版


题目描述

任意输入一个自然数,输出该自然数的各位数字组成的最大数。例如,输入 1593 ,则输出为 9531 。

输入描述

自然数 n

输出描述

各位数字组成的最大数

样例输入
1593
样例输出
9531

正确代码

法一注释版
#include<stdio.h> int main () { int n,i,j,q,a[50]; // 声明变量n用于存储输入的数字,i、j、q用于循环,a[50]是一个数组,用于存储数字的每一位scanf("%d",&n); // 读取nfor(i=0;; i++) { // 一个无限循环,用于分解数字n的每一位a[i]=n%10; // 取n的最后一位数字,即n除以10的余数,存储在数组a的第i个位置n=n/10; // 将n除以10,去掉最后一位数字if (n==0) // 如果n变为0,说明数字已经被完全分解break; // 跳出循环}int t; // 声明一个临时变量t,用于交换数字for(j=1; j<i; j++) { // 外层循环,控制排序的轮数,从1开始,因为第0位不需要排序for(q=0; q<=i-j; q++) { // 内层循环,用于比较并交换相邻的数字if(a[q]<a[q+1]) { // 如果当前位置的数字小于下一个位置的数字t=a[q]; // 交换两个数字a[q]=a[q+1];a[q+1]=t;}}}for(q=0; q<=i; q++) // 循环输出排序后的数字printf("%d",a[q]); // 打印数组a中的每个元素
} // 主函数的结束
简洁版
#include<stdio.h>
int main () {int n,i,j,q,a[50];scanf("%d",&n);for(i=0;;i++) {a[i]=n%10;n=n/10;if (n==0)break;}int t;for(j=1; j<i; j++) {for(q=0; q<=i-j; q++) {if(a[q]<a[q+1]) {t=a[q];   a[q]=a[q+1];a[q+1]=t;}}}for(q=0;q<=i;q++)printf("%d",a[q]);       
}
法二注释版
#include <stdio.h>  // 包含标准输入输出库,用于scanf和printf函数
#include <stdlib.h> // 包含标准库,提供qsort函数
#include <string.h> // 包含字符串处理库,提供strlen函数// 比较函数,用于qsort比较两个元素的大小
int compare(const void *a, const void *b) {return *(char *)b - *(char *)a; // 如果b指向的字符大于a指向的字符,则返回正数;如果小于,则返回负数;如果相等,则返回0
}int main() {char a[50]; // 声明一个字符数组scanf("%s", &a); // 读取一个字符串aint l = strlen(a); // 使用strlen函数计算字符串a的长度,并存储在变量l中qsort(a, l, sizeof(char), compare); // 使用qsort函数对字符串a进行排序// a是要排序的数组的首地址// l是要排序的元素个数// sizeof(char)指定每个元素的大小,这里是1,因为a是字符数组// compare是自定义的比较函数,用于告诉qsort如何比较两个元素printf("%s\n", a); // 打印排序后的字符串return 0; // 程序正常结束
}
简洁版
#include <stdio.h>
#include <stdlib.h>
#include <string.h>int compare(const void *a, const void *b) {return *(char *)b - *(char *)a;
}int main() 
{char a[50];scanf("%s",&a);int l=strlen(a);qsort(a, l, sizeof(char), compare); printf("%s\n", a); return 0;
}

总结

这段代码的主要功能是读取用户输入的一个字符串,然后使用 qsort 函数对这个字符串中的字符进行升序排序,并输出排序后的结果。qsort 是一个通用的排序函数,它可以对任何类型的数组进行排序,只要提供了正确的比较函数。在这个例子中,比较函数 compare 被设计为按照字符的ASCII值进行比较,从而实现字符的升序排序。

http://www.lryc.cn/news/503148.html

相关文章:

  • 【Git系列】根据提交打印邮箱
  • Nginx在处理客户端请求的并发性发面是否依赖Linux的多线程原理
  • Python生成对抗神经网络GAN预测股票及LSTMs、ARIMA对比分析ETF金融时间序列可视化
  • 深入了解C++中const的用法
  • 【Linux金典面试题(上)】41道Linux金典面试问题+详细解答,包含基本操作、系统维护、网络配置、脚本编程等问题。
  • 利用Python实现多元回归预测汽车价格
  • 抓包软件fiddler和wireshark使用手册
  • 初识三大 Observer
  • Eclipse MAT(Memory Analyzer Tool) 使用手册
  • TongWe7.0-东方通TongWeb控制台无法访问 排查
  • Ariba Procurement: Administration_Master data
  • 爬虫学习案例4
  • Angular模块化应用构建详解
  • 51c大模型~合集89
  • 【蓝桥杯备战】Day 1
  • FedAdam算法:供给方信用,数据质量;更新一致性
  • 内存卡格式化后的数据恢复全攻略
  • 介绍交叉熵损失(Cross-Entropy Loss)以及交叉熵在对比学习中的应用:中英双语
  • RabbitMQ的几个概念
  • Ollama部署大模型并安装WebUi
  • Debedium如何忽略Oracle的purge命令
  • PlantUML 语言
  • linux的 .so和.ko文件分别是什么?主要区别是什么?
  • XX服务器上的npm不知道咋突然坏了
  • 数据结构(优先级队列 :Priority Queue)
  • nginx.conf 请求时间部分参数说明新手教程
  • 【Linux-ubuntu通过USB传输程序点亮LED灯】
  • 《开源时间序列数据:探索与应用》
  • 三相异步电动机跳闸的原因是什么?
  • 连续思维链Coconut ,打开LLM推理新范式