这个题目在PTA上面超时了,请问要怎么改进
题目5个数排序这是一个签到题。要求你对五个数排序并且输出。例如:本题目要求读入一行五个数字,然后排序并输出排序后的五个数字。
输入格式:请在这里写输入格式。例如:输入在一行中并且给出5个数字
输出格式:请在这里描述输出格式。例如:对每一组输入,在一行中输出排序完的数字。(末尾无空格o( ̄▽ ̄)ブ)
输入样例:在这里给出一组输入。例如:
3 2 1 4 5
输出样例:在这里给出相应的输出。例如:
1 2 3 4 5
我的代码#include <stdio.h>
int main()
{
int num;
int i,j,temp;
for(i=0;i<=4;i++)
{
scanf("%d",&num);
}
for(i=0;i<4;i++)
{
for(j=i+1;j<=4;j++)
{
if(num>num)
{
temp=num;
num=num;
num=temp;
}
}
}
for(i=0;i<=4;i++)
{
printf("%d ",num);
}
printf("\b");
return 0;
}
但结果是
image-for-quicker.test.upcdn.net/image/img20211019102515824.jpg
而在codeblock里面是可以运行的,所以想问怎么改进,缩短代码运行时间。
只有 5 个数字,为什么会超时? 你用的是插入排序法 Insertion Sort,时间复杂度:O(n^2) 试试这个代码呢
#include <stdio.h>
int main(void)
{
int d , i , j , k ;
for(i = 0 ; i < 5 ; i ++) scanf("%d" , & d) ;
for(i = 0 ; i < 4 ; i ++) {
for(j = i + 1 ; j && d < d ; j --) {
k = d ;
d = d ;
d = k ;
}
}
for(i = 0 ; i < 5 ; i ++) {
if(i) printf(" ") ;
printf("%d" , d) ;
}
printf("\n") ;
} int num[4];
int i,j,temp;
for(i=0;i<=4;i++)
傻眼貓咪 发表于 2021-10-19 10:53
只有 5 个数字,为什么会超时?
stack-buffer-overflow 人造人 发表于 2021-10-19 12:25
stack-buffer-overflow
感恩,受教了,原来是栈缓冲区溢出啊{:5_99:} 傻眼貓咪 发表于 2021-10-19 12:29
感恩,受教了,原来是栈缓冲区溢出啊
我一开始也觉得奇怪
只有 5 个数字,为什么会超时?
于是我先是百度找速度快的排序算法,然后又想到了内联函数内联汇编这些
我写完了归并排序,然后发现已经有别人回复了,我的代码就不贴了
那就看一看别人写的代码吧,然后发现两个算法差不多
然后发现了stack-buffer-overflow
^_^ 人造人 发表于 2021-10-19 12:38
我一开始也觉得奇怪
只有 5 个数字,为什么会超时?
谢谢,受教了
页:
[1]