| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1286 人关注过本帖
标题:排序 简单插入法
只看楼主 加入收藏
AirF3101
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2017-3-13
结帖率:66.67%
收藏
已结贴  问题点数:5 回复次数:10 
排序 简单插入法
程序代码:
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef int elemtype;

struct_table
{
    int arr[];
    
};

void insert_sort(int arr[], int length)
{
    int j;
    int tail;
    tail = 1;
    while(tail<table->length)
    {
        temp = table->arr[tail];
        j = tail - 1;
        while (j > 1)
            if (temp.key > table->arr[j].key)
                table->arr[j + 1] = table->arr[j];
            else
            {
                table->arr[j + 1] = temp;
                break;
                j--;
            }
        tail++;
    }
}



int main()
{
    int arr[] = { 12,56,21,10,76,43,88,92,38 };

    select_sort(arr, sizeof(arr) / sizeof(arr[0]));

    for (int i = 0;i < sizeof(arr) / sizeof(arr[0]);i++);
    {
        printf("%d", arr[i]);
    }
    return 0;
}



求大神改改
搜索更多相关主题的帖子: 插入法 
2017-06-07 09:43
AirF3101
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2017-3-13
收藏
得分:0 
有急用,谢谢
2017-06-07 09:45
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:3 
struct_table
{
    int arr[];
   
};

很好奇这是什么编译器~~~~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-06-07 19:09
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
应该说明是什么问题~是编译过不了还是运行结果问题~~~~~~

PS:当然我这个编译器是过不了那个奇葩的

struct_table
{
    int arr[];
   
};

还更好奇这代码是怎么来的~
table->length
感觉要改改结构体的声明部分~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-06-07 19:39
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:3 
回复 3楼 九转星河
灵活域数组,用法跟指针申请动态内存类似。

曾经是GCC的扩展,后C99添加,别名零长数组。

[此贴子已经被作者于2017-6-7 21:08编辑过]


09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-06-07 20:59
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:0 
程序代码:
void insert_sort(int arr[], int length)
{
    int j;
    int tail;
    tail = 1;
    while(tail<table->length)//table这个指针变量是从哪里来的?你的代码从这里开始就已经错了,下面的代码都懒的看了。
    {
        temp = table->arr[tail];//灵活域数组需要先申请内存,再使用,所以,这里继续错。
        j = tail - 1;
        while (j > 1)
            if (temp.key > table->arr[j].key)
                table->arr[j + 1] = table->arr[j];
            else
            {
                table->arr[j + 1] = temp;
                break;
                j--;
            }
        tail++;
    }
}

09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-06-07 21:01
AirF3101
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2017-3-13
收藏
得分:0 
回复 6楼 renkejun1942
就是要补充,不完整,我也懵
2017-06-07 21:53
AirF3101
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2017-3-13
收藏
得分:0 
回复 4楼 九转星河
就是没有写完,需要补充,我也懵
2017-06-07 21:53
AirF3101
Rank: 1
等 级:新手上路
帖 子:29
专家分:0
注 册:2017-3-13
收藏
得分:0 
回复 6楼 renkejun1942
帮我补充一下,谢谢了,原谅还是新手,哈哈
2017-06-07 21:54
renkejun1942
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:不是这样
等 级:贵宾
威 望:33
帖 子:1645
专家分:5297
注 册:2016-12-1
收藏
得分:0 
回复 7楼 AirF3101
你错的太多了,从头开始写吧。

你只是数组排序,不需要使用到结构,更加不需要使用到零长数组。

我帮不了你,今天,上班太累,喝酒喝的我头晕呼呼的。

[此贴子已经被作者于2017-6-7 22:06编辑过]


09:30 05/21 种下琵琶种子,能种活么?等待中……
21:50 05/27 没有发芽。
20:51 05/28 没有发芽。
23:03 05/29 没有发芽。
23:30 06/09 我有预感,要发芽了。
2017-06-07 22:02
快速回复:排序 简单插入法
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.019086 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved