曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 5519|回复: 0
打印 上一主题 下一主题

在一个已排序好的数组中插入一个元素

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34397
跳转到指定楼层
楼主
发表于 2008-11-23 15:27:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
百度知道提问:

已有一个排好序的数组{3,6,9,23,34,56,78},现输入一个数,要求按原来的排序的规则将它插入数组中。

我的解法:

#include <stdio.h>

#define MAX 20

int main(void)
{
    int a[MAX] = {3,6,9,23,34,56,78};
    int i = 0;
    int k = 0;
    int m = 0;
    int temp;

    while( a != 0 && a[i+1] != 0 && (i+1) < MAX )
        i++;
   
    k = i;
    m = i;
    i = 0;

    printf("被初始化的数组个数为: %d\n",k+1);

    if( k == MAX - 1){
        printf("数组已满,无法再插入\n");
        return 0;
    }

    printf("请输入一个整数以进行排序: ");

    scanf("%d",&temp);

    while( temp > a )
    {
        i++;
    }

    while( k-i >= 0 )
    {
        a[k+1] = a[k];
        k--;
    }
    a = temp;
    m = m + 1;

    printf("新的数组为: ");
   
    for(i=0; i<m+1; i++)
    {
        printf("%d ", a);
    }

    printf("\n");
   
    return 0;
}
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-6-17 18:37 , Processed in 0.066186 second(s), 22 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表