C语言中,以命令行输入一组数字,并以从小到大排序输出!

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言中,以命令行输入一组数字,并以从小到大排序输出!相关的知识,希望对你有一定的参考价值。

需要用到atoi函数!比如说连续输入12 ,09 ,27,58,01等数字 先用这个函数把输入的12等数字转换成代表大小的数值,赋值给一个数组,然后比较大小,从小到大排列后再赋值给另外一个数组。并输出结果!

楼上的都没明白楼主的意思。O(∩_∩)O~
#include<stdio.h>
#include <math.h>
#define N 10
void main()

char a[5];
int i,n,temp;
int num1[N],num2[N];
printf("请输入要输入的数字个数:");
scanf("%d",&n);
for(i=0;i<n;i++)

scanf("%s",a);
num1[i]=atoi(a);

for(int j=0;j<n;j++) //从小到大排序
for(int k=j+1;k<n;k++)

if(num1[j]>num1[k])

temp=num1[j];
num1[j]=num1[k];
num1[k]=temp;


for(i=0;i<n;i++)
num2[i]=num1[1];
printf("排列后的数组是:\n");
for(i=0;i<n,i++)

if(i%5==0) putchar('\n');
printf("%d\t",num2[i]);

system("pause");
参考技术A #include<stdio.h>
void main()

int n[5],temp;
for(int i=0;i<5;i++)
scanf("%d",&n[i]); //数组输入
for(int j=0;j<5;j++) //从小到大排序
for(int k=j+1;k<5;k++)

if(n[j]>n[k])

temp=n[j];
n[j]=n[k];
n[k]=temp;


for(int l=0;l<5;l++)
printf("%d ",n[l]);

参考技术B #include<stdio.h>

void main()

int i,j,test;
int a[5];
for(i=0;i<5;i++)

scanf("%d",&a[i]);


for(i=0;i<5;i++)

for(j=0;j<5;j++)

if(a[i]<a[j])

test=a[i];
a[i]=a[j];
a[j]=test;







for(i=0;i<5;i++)

printf("%d,",a[i]);



追问

你这个函数我输入系统 没输出啊!

参考技术C 楼上的都没明白楼主的意思。O(∩_∩)O~
#include
#include
#define
N
10
void
main()

char
a[5];
int
i,n,temp;
int
num1[N],num2[N];
printf("请输入要输入的数字个数:");
scanf("%d",&n);
for(i=0;i
num1[k])

temp=num1[j];
num1[j]=num1[k];
num1[k]=temp;


for(i=0;i
评论
0
0
0
加载更多

E - 排序

输入一行数字,如果我们把这行数字中的‘5’都看成空格,那么就得到一行用空格分割的若干非负整数(可能有些整数以‘0’开头,这些头部的‘0’应该被忽略掉,除非这个整数就是由若干个‘0’组成的,这时这个整数就是0)。 

你的任务是:对这些分割得到的整数,依从小到大的顺序排序输出。 

Input输入包含多组测试用例,每组输入数据只有一行数字(数字之间没有空格),这行数字的长度不大于1000。   

输入数据保证:分割得到的非负整数不会大于100000000;输入数据不可能全由‘5’组成。 
Output对于每个测试用例,输出分割得到的整数排序的结果,相邻的两个整数之间用一个空格分开,每组输出占一行。 
Sample Input

0051231232050775

Sample Output

0 77 12312320

解法:
 1 #include <iostream>
 2 #include<stack>
 3 #include <algorithm>
 4 #include <string.h>
 5 using namespace std;
 6 
 7 const int MAX = 1000+500;
 8 
 9 int main()
10 {
11 
12 
13     stack<int>S;
14     char temp[MAX];
15 
16 //   while(cin>>temp)
17  //       S.push(temp - ‘0‘);
18 
19     while(cin>>temp)
20     {
21         int N = 0;
22         long long a[MAX];
23 
24         int temp0;
25         temp0 = strlen(temp);
26         for(int i = 0;i<temp0;i++)
27             S.push(temp[i]-0);
28         while(!S.empty())
29         {
30             int b[MAX];
31             int Nb = 0;
32             long long sum = 0;
33             while(!S.empty())
34             {
35                 if(S.top() == 5)
36                 {
37                     S.pop();
38                     break;
39                 }
40                 b[Nb++] = S.top();
41                 S.pop();
42             }
43             if(Nb != 0)
44             {
45                 for(int i = Nb-1;i>=0;i--)
46                     sum = sum*10 + b[i];
47                 a[N++] = sum;
48             }
49 
50         }
51 
52         sort(a,a+N);
53 
54         cout<<a[0];
55         for(int i = 1;i < N;i++)
56             cout<< <<a[i];
57         cout<<endl;
58 
59     }
60 
61 
62 
63 
64     return 0;
65 }

 

以上是关于C语言中,以命令行输入一组数字,并以从小到大排序输出!的主要内容,如果未能解决你的问题,请参考以下文章

C语言,二维点按照x坐标大小排序题。

C语言将一组数从大到小排序 只能移动相邻的数 并且要求步骤最小 怎么设计逻辑

C语言 数组与函数 写一函数,对输入的一组整数按由小到大的顺序排序,在main主函数调用该

DS排序--快速排序

利用Java语言,实现数组的排序

C语言:对输入的十个数进行从小到大排序