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语言将一组数从大到小排序 只能移动相邻的数 并且要求步骤最小 怎么设计逻辑