| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2214 人关注过本帖
标题:c语言程序设计,数组编号,求思路
只看楼主 加入收藏
Anado
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2019-11-11
结帖率:33.33%
收藏
已结贴  问题点数:5 回复次数:7 
c语言程序设计,数组编号,求思路
从键盘输入10个整数存放在数组a中,然后对数组a中的10个整数按从小到大连续编号,要求不能改变数组a中元素的顺序,且相同的整数要具有相同的编号。最后输出数组a及其元素的编号。

例如:
 输入:

5    3    4    7    3    5    6    9   21     100


则输出为:

5    3    4    7    3    5    6    9   21     100

3    1    2    5    1    3    4    6    7       8
搜索更多相关主题的帖子: 整数 编号 数组 c语言 思路 
2019-12-22 13:49
wlcsss123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:7
专家分:19
注 册:2019-9-16
收藏
得分:2 
感觉好难啊  白学了几个月
2019-12-22 14:16
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:2 
程序代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define COUNT 10

#define SIZE_OF_ARRAY(array) (sizeof(array) / sizeof(array[0]))

typedef struct
{
    int value;
    int original_order;
    int sorted_order;
} value_order_t;

void display_array(int * array, size_t size)
{
    printf("[ ");
    for(int i = 0; i < size; i++)
    {
        printf("%d ", array[i]);
    }
    printf("]\n");
}

int main(void)
{
    const int array_count = COUNT;
    int input_array[array_count];
    value_order_t value_order_array[array_count];
    int order_array[array_count];
    
    
    printf("Please input integer array: ");
    if(scanf("%d %d %d %d %d %d %d %d %d %d", &input_array[0], &input_array[1], &input_array[2], &input_array[3], &input_array[4], &input_array[5], &input_array[6], &input_array[7], &input_array[8], &input_array[9])!= 10)
    {
        fprintf(stderr, "Size of integer array isn't %d", array_count);
        return EXIT_FAILURE;
    }
    printf("\n");
    
    printf("Original integer array: ");
    display_array(input_array, SIZE_OF_ARRAY(input_array));
    
    for(int i = 0; i < array_count; i++)
    {
        value_order_array[i].value = input_array[i];
        value_order_array[i].original_order = i;
        value_order_array[i].sorted_order = -1;
    }
    
    for(int i = 0; i < array_count - 1; i++)
    {
        for(int j = i; j < array_count; j++)
        {
            if(value_order_array[i].value > value_order_array[j].value)
            {
                value_order_t temp = value_order_array[i];
                value_order_array[i] = value_order_array[j];
                value_order_array[j] = temp;
            }
        }
    }
    
    value_order_array[0].sorted_order = 0;
    for(int i = 1; i < array_count; i++)
    {
        if(value_order_array[i].value == value_order_array[i - 1].value)
        {
            value_order_array[i].sorted_order = value_order_array[i - 1].sorted_order;
        }
        else
        {
            value_order_array[i].sorted_order = value_order_array[i - 1].sorted_order + 1;
        }
    }
    
    for(int i = 0; i < array_count; i++)
    {
        for(int j = 0; j < array_count; j++)
        {
            if(value_order_array[j].original_order == i)
            {
                order_array[i] = value_order_array[j].sorted_order + 1;
            }
        }
    }
    
    printf("Sorted order: ");
    display_array(order_array, SIZE_OF_ARRAY(order_array));
    
    return EXIT_SUCCESS;
}


[此贴子已经被作者于2019-12-22 16:39编辑过]

2019-12-22 16:34
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:0 
随便写的一个算法。应该有更好的算法,因为这个算法是最低效的。你可以在找找看。
2019-12-22 16:35
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:2 
这个题目不太好,因为数据的数量太小了,才10个。即便想出一个高效的算法,可能也体现不出效率来。

a. 已知:
   5 3 4 7 3 5 6 9 21 100

b. 添上序号
   5 3 4 7 3 5 6 9 21 100
   1 2 3 4 5 6 7 8  9  10

c. 根据第一行排序,得
   3 3 4 5 5 6 7 9 21 100
   2 5 3 1 6 7 4 8  9  10

d. 添上序号,得
   3 3 4 5 5 6 7 9 21 100 // 这一行其实没用了
   2 5 3 1 6 7 4 8  9  10
   1 1 2 3 3 4 5 6  7   8

e. 根据d中第二行排序,得
   5 3 4 7 3 5 6 9 21 100 // 这一行其实就是a
   1 2 3 4 5 6 7 8  9  10
   3 1 2 5 2 3 4 6  7   8

f. 输出e中的第一行和第三行

假如我用C++来做的话,代码应该是
程序代码:
#include <cstdio>
#include <utility>
#include <algorithm>
using namespace std;

void foo( const int (&a)[10] )
{
    pair<int,int> b[] = { {a[0],1}, {a[1],2}, {a[2],3}, {a[3],4}, {a[4],5}, {a[5],6}, {a[6],7}, {a[7],8}, {a[8],9}, {a[9],10} };
    sort( begin(b), end(b), [](auto& lhs,auto& rhs){return lhs.first<rhs.first;} );

    int index=1, pre=b[0].first;
    for( auto& value : b )
    {
        if( value.first != pre )
        {
            pre = value.first;
            ++index;
        }
        value.first = index;
    }
    sort( begin(b), end(b), [](auto& lhs,auto& rhs){return lhs.second<rhs.second;} );

    for( size_t i=0; i!=size(a); ++i )
        printf( "%d%c", a[i], " \n"[i+1==size(a)] );
    for( size_t i=0; i!=size(b); ++i )
        printf( "%d%c", b[i].first, " \n"[i+1==size(b)] );
}

int main( void )
{
    int a[] = { 5, 3, 4, 7, 3, 5, 6, 9, 21, 100 };
    foo( a );
}
2019-12-22 17:33
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:0 
C代码是
程序代码:
#include <stdio.h>
#include <stdlib.h>

int cmp_b_first( const void* pl, const void* pr )
{
    if( *(int*)pl < *(int*)pr )
        return -1;
    if( *(int*)pl > *(int*)pr )
        return +1;
    return 0;
}

void foo( const int a[static 10] )
{
    int b[][2] = { {a[0],1}, {a[1],2}, {a[2],3}, {a[3],4}, {a[4],5}, {a[5],6}, {a[6],7}, {a[7],8}, {a[8],9}, {a[9],10} };
    qsort( b, 10, sizeof(*b), &cmp_b_first );

    int index=1, pre=b[0][0];
    for( size_t i=0; i!=10; ++i )
    {
        if( b[i][0] != pre )
        {
            pre = b[i][0];
            ++index;
        }
        b[i][0] = index;
    }

    int c[10];
    for( size_t i=0; i!=10; ++i )
        c[b[i][1]-1] = b[i][0];

    for( size_t i=0; i!=10; ++i )
        printf( "%d%c", a[i], " \n"[i+1==10] );
    for( size_t i=0; i!=10; ++i )
        printf( "%d%c", c[i], " \n"[i+1==10] );
}

int main( void )
{
    int a[] = { 5, 3, 4, 7, 3, 5, 6, 9, 21, 100 };
    foo( a );
}

2019-12-22 18:07
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:0 
回复 6楼 rjsp
" \n"[i+1==10]
这是个什么用法?
2019-12-22 22:10
八画小子
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:贵宾
威 望:37
帖 子:709
专家分:2063
注 册:2010-11-11
收藏
得分:0 
回复 6楼 rjsp
已经了解。非常佩服你这么简练地处理这个问题。受教了。
2019-12-22 22:13
快速回复:c语言程序设计,数组编号,求思路
数据加载中...
 
   



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

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