| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 7312 人关注过本帖
标题:实现一个函数,扩充数组的大小
只看楼主 加入收藏
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
结帖率:89.47%
收藏
已结贴  问题点数:20 回复次数:11 
实现一个函数,扩充数组的大小
实现一个函数,扩充数组的大小。
函数声明为:
int doubleCapacity(int list, int size, int addSize);
例如,下面的代码的输出为:1 2 3 4 5 0 0 0 0 0
int list[5]={1,2,3,4,5};
int *newlist = doubleCapacity(list,5);
for(int i=0;i<2*5;i++)
  printf("%d ",newlist[i]);
Input
第一行为两个数字m和n,m是原来数组的大小,n是增加的大小。m在1和10之间,n在5和10之间。
第二行为输入m个数字,组成维度为m的数组。
Output
输出扩充后的数组,输出格式为printf("%d ",newlist[i]);

#include<stdio.h>
#include<stdlib.h>
int main() {
        int *doubleCapacity(int *list, int size, int addSize);
        int m, n;
        scanf("%d", &m);
        scanf("%d", &n);
 
        int a[10];
        int i = 0;
        for (i = 0; i < m; i++)
                scanf("%d", &a[i]);
 
        int *newlist = doubleCapacity(a, m, n);
 
        for (i = 0; i < (m + n); i++)
                printf("%d ", newlist[i]);
        free(newlist);
        return 0;
}

函数应该怎么写?
搜索更多相关主题的帖子: include 
2016-12-05 19:18
xufan
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:6
帖 子:232
专家分:804
注 册:2008-10-20
收藏
得分:2 
数组是固定长度的,不能动态增长!!!

~~~~~~我的明天我知道~~~。
2016-12-05 19:37
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
回复 2楼 xufan
一道题目,我也不是很知道。
2016-12-05 19:44
groveer
Rank: 3Rank: 3
来 自:世界的一角
等 级:论坛游侠
威 望:1
帖 子:77
专家分:182
注 册:2013-11-18
收藏
得分:10 
看楼主的程序 应该不是数组是指针的问题吧 楼主可以看看这段代码
程序代码:
int main() {
    int *doubleCapacity(int *list, int size, int addSize);
    int m, n;
    scanf("%d", &m);
    scanf("%d", &n);

    int a[10];
    int i = 0;
    for (i = 0; i < m; i++)
        scanf("%d", &a[i]);

    int *newlist = doubleCapacity(a, m, n);

    for (i = 0; i < (m + n); i++)
        printf("%d ", newlist[i]);
    free(newlist);
    system("pause");
    return 0;
}

int *doubleCapacity(int *list, int size, int addSize)
{
    int *p = (int*)malloc((size + addSize) * sizeof(int));
    for (int i = 0; i < size; i++)
        *(p + i) = *(list + i);
    for (int i = size; i < size + addSize; i++)
        *(p + i) = 0;
    return p;
}

付出不亚于任何人的努力~
2016-12-05 20:08
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:5 
#include <stdio.h>
#include <stdlib.h>

int *doubleCapacity(int *list, int size, int addSize)
{
    list = (int *)realloc(list, (size+addSize)*sizeof(int));
    int i;
    for (i=size; i<(size+addSize); i++)
        list[i] = 0;
    return list;
}

int main()
{
    int i;
    int *list=(int *)malloc(5*sizeof(int));
    for (i=0; i<5; i++)
        list[i] = i+1;
    list = doubleCapacity(list, 5, 5);
    for (i=0; i<10; i++)
        printf("%d ", list[i]);
    free(list);
    return 0;
}
2016-12-05 20:39
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:3 
回复 楼主 ClearningC
int *newlist = doubleCapacity(list,5);
这个有点没道理,左边不是个指针int*吗,怎么又能把一个int型的返回值传给它?
2016-12-05 20:46
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
回复 4楼 groveer
对,是指针。刚学的指针,没怎么懂。有点懵的感觉。
谢谢你的程序了,容我慢慢理解消化。
2016-12-05 22:24
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
如果是用指针,一开始就没必要声明数组大小啊。直接用int *p=(int *)malloc(n*sizeof(int));就行了~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-05 22:33
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
回复 5楼 吹水佬
list = (int *)realloc(list, (size+addSize)*sizeof(int));
这一步不懂,realloc是一个函数吗?(还没遇到过)

main函数里,为什么把size,addSize都赋值为5?
(如果把赋的值再转回size,addSize,应该没差吧?)
2016-12-05 22:37
ClearningC
Rank: 2
等 级:论坛游民
帖 子:98
专家分:43
注 册:2016-10-26
收藏
得分:0 
回复 6楼 yangfrancis
作为一只刚接触编程三个月的小白(应该不算小白了吧),现在还是不是很懂。
2016-12-05 22:39
快速回复:实现一个函数,扩充数组的大小
数据加载中...
 
   



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

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