求解为什么插入排序失效?奇怪的现象,为什么a[i]不会更新呢?

我自己的代码:为什么无法使用快排?求助! 

#include<stdio.h>
#include<string.h>
/*
问题描述
  给定一个长度为n的数列,将这个数列按从小到大的顺序排列。1<=n<=200
输入格式
  第一行为一个整数n。
  第二行包含n个整数,为待排序的数,每个整数的绝对值小于10000。
输出格式
  输出一行,按从小到大的顺序输出排序后的数列。
*/
int main()
{

    int n;
    int i;
    int j;
    int a[201];
    scanf("%d",&n);
    //读入数据放入数组
    for (i = 0; i < n; i++)
    {
        scanf("%d",&a[i]);        
    }
    //插入排序
    for ( i = 1; i < n; i++)
    {
        int flag = a[i];
        for ( j = i-1; j >=0 && a[j]>a[i]; j--)
        {
            a[j+1] = a[j];
        }
        /***出错点!!!
         **验证a[i]出错
        printf("a[i]=%d\n",a[i]);
        ***/
        a[j+1] = a[i];
                
    }
    //打印排序后的数组
    for ( i = 0; i < n; i++)
    {
        printf("%d ",a[i]);
    }
    
    return 0;
}

运行结果:

 

正确执行的代码对比:

#include<stdio.h>
#include<string.h>

int main()
{

    int n;
    int i;
    int j;
    int a[201];
    scanf("%d",&n);
    //读入数据放入数组
    for (i = 0; i < n; i++)
    {
        scanf("%d",&a[i]);        
    }
    //正确的插入排序算法
    for (i = 1; i < n; i++)
	{
		int flag = a[i];   //记录arr[i] 的值
		for (j = i - 1; j >= 0 && a[j] > flag;j--)  //当arr[i]前面的一个数字比a[i]大时
		{
			a[j + 1] = a[j];  //将arr[i] 和其前一个数字进行交换
		}
		a[j + 1] = flag;
 
	}

    //打印排序后的数组
    for ( i = 0; i < n; i++)
    {
        printf("%d ",a[i]);
    }
    
    return 0;
}

不懂为什么一定要用flag 来暂存\large a[i]的值?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值