| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2324 人关注过本帖
标题:关于通过指针变量来实现参数的间接双向传递的问题
只看楼主 加入收藏
z450558237
Rank: 2
等 级:论坛游民
帖 子:48
专家分:11
注 册:2014-10-21
结帖率:55.56%
收藏
已结贴  问题点数:10 回复次数:6 
关于通过指针变量来实现参数的间接双向传递的问题
题目如下:
  1.找出100-999之间的水仙花数构成一个数组。输出该数组,每个数占5列,左对齐,每行输出3个数。(水仙花数:n位数(n>=3),每个位上的数字的n次幂之和等于它本身。例如:1^3+5^3+3^3=153)
2.将该数组中的数按其十位数的大小非降序排列,结果仍保存在原数组中。输出该数组,每个数占5列,左对齐,每行输出6个数。
3.将该数组中的每个数的构成数字拆解形成若干独立的数字,结果仍然保存在该数组中(构成数字的顺序与原数组保持一致。例如:原数组{153,370}=>新数组{1,5,3,3,7,0})。输出该数组,每个数占5列,左对齐,每行输出10个数。
4.去除新数组中的冗余数字(仅保留重复数字的第一次出现),结果仍然保存在该数组中,输出该数组,每个数占5列,左对齐,每行输出10个数。(例如:原数组{1,5,3,3,7,0}=>新数组{1,5,3,7,0})  

主函数如下:
#define MAX 100
int main()
{
int arr[MAX],count;
        printf("水仙花数列表:\n");
        count=fill(arr);                //生成水仙花数数组
        display(arr,count,3);            //按指定的每行数组个数显示数组
        printf("排序后数字列表:\n");
        msort(arr,count);                //按十位数字非降序排序
        display(arr,count,6);
        printf("构成数字列表:\n");
        msplit(arr,&count);        //拆解构成数字,更新数组
        display(arr,count,10);
        printf("去除冗余后数字列表:\n");
        count=mremove(arr,count);        //去除数组中的冗余数字,保留其首次出现
        display(arr,count,10);
return 0;
}



下面是我写的代码:
#include <stdio.h>

 #define MAX 100

int fill(int arr[])
{
    int i,count,sum,m,n,k;
    count=0;
    for(i=100,sum=0;i<=999;i++)
    {
        m=i/100;
        n=i/10%10;
        k=i%10;
        sum=m*m*m+n*n*n+k*k*k;
        if(sum==i)
        {
            arr[count]=i;
            count++;
        }
    }
    return count;
    printf("\n");
}

void display(int arr[],int count,int n)
{
    int i;
    for(i=0;i<count;i++)
    {
        printf("%5d",arr[i]);
        if((i+1)%n==0)
            printf("\n");
    }
    printf("\n");
}

void msort(int arr[],int count)
{
    int i,j,temp,m,n;
    for(i=0;i<count-1;i++)
    {
        for(j=0;j<count-i-1;j++)
        {
            m=arr[j]/10%10;
            n=arr[j+1]/10%10;
            if(m>n)
            {
                temp=arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=temp;
            }
        }
    }
}

void msplit(int arr[],int *count)
{
   
}

红色字体的函数不会写了,老师说这个&count是为了通过指针变量来实现参数的间接双向传递;求教是怎么实现的
搜索更多相关主题的帖子: 水仙花 
2015-12-23 08:12
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:5 
这个感觉不是很难  神马双向传递 是你们老师故作高深吧

说说  msplit(arr,&count);        //拆解构成数字,更新数组  这个东东准备干什么   是把神马放到数组里了

DO IT YOURSELF !
2015-12-23 08:41
z450558237
Rank: 2
等 级:论坛游民
帖 子:48
专家分:11
注 册:2014-10-21
收藏
得分:0 
回复 2楼 wp231957
.将该数组中的每个数的构成数字拆解形成若干独立的数字,结果仍然保存在该数组中(构成数字的顺序与原数组保持一致。例如:原数组{153,370}=>新数组{1,5,3,3,7,0})。输出该数组,每个数占5列,左对齐,每行输出10个数。
2015-12-23 08:42
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
例如:原数组{153,370}=>新数组{1,5,3,3,7,0})  你的arr数组不就是一维数组吗  怎么出现{153,370} 这个东东

DO IT YOURSELF !
2015-12-23 08:44
z450558237
Rank: 2
等 级:论坛游民
帖 子:48
专家分:11
注 册:2014-10-21
收藏
得分:0 
回复 4楼 wp231957
就是count是原来arr数组长度,现在arr里面的数字拆解了,count要变成新的arr的长度
2015-12-23 08:50
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
看看这段代码  能不能有些用处
程序代码:
#include<stdio.h>

void msplit(int* arr,int *count)
{
    int t=0;
    int tmp[1000]={0};
    int a,b,c;
    for(int i=0;*(arr+i)!=0;i++)
    {
        a=*(arr+i)/100;
        b=(*(arr+i)-*(arr+i)/100*100)/10;
        c=*(arr+i)%10;
        tmp[t]=a;
        tmp[++t]=b;
        tmp[++t]=c;
        t++;
    }
    for(int i=0;i<t;i++)
    {
        *(arr+i)=tmp[i];
    }
    *count=t;
}
int main()
{
    int arr[1000]={0};
    int count=0;
    arr[0]=153;
    arr[1]=370;
    arr[2]=456;
    arr[3]=579;
    msplit(arr,&count);
    for(int i=0;i<count;i++) printf("%d\n",arr[i]);
    return 0;
}

DO IT YOURSELF !
2015-12-23 10:51
ntprc0x
Rank: 3Rank: 3
等 级:论坛游侠
威 望:2
帖 子:23
专家分:130
注 册:2015-11-14
收藏
得分:5 
也分享下
程序代码:
void msplit(int arr[],int *count)
{
    char a[MAX];
    int m,i;
       for(m=0,i=0;i<*count;i++,m+=3)
           sprintf(a+m,"%d",arr[i]);         

       for(i=0;i<m;i++)
           arr[i] = a[i]-'0';
       *count = i;
}

int mremove(int arr[],int count)
{
    int tag[10] = {0};
    int i,j;
    for(i=0,j=0;i<count;i++)
    {
        if(tag[arr[i]]==0)
        {
            arr[j++] = arr[i];
            tag[arr[i]] = 1;
        }
    }
    return j;
}

2015-12-23 20:10
快速回复:关于通过指针变量来实现参数的间接双向传递的问题
数据加载中...
 
   



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

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