上一题下一题
跳转到
 
 
  世界如此多姿,发展如此迅速,窥一斑未必还能知全豹。但正如万花筒一样,每一个管窥都色彩斑斓。  
 
 
  知识通道 | 学习首页 | 教师首页 | PK首页 | 知识创造首页 | 企业首页 | 登录
 
本文对应知识领域
c语言 上机题库(第三部分 编程题)
作者:未知 申领版权
2010年12月12日 共有 1545 次访问 【添加到收藏夹】 【我要附加题目
受欢迎度:

    第三部分 编程题
    1.m个人的成绩存放在score数组中,请编写函数fun,它的功能是:将低于平均分的人数作为函数值返回,将低于平均分的分数放在below所指的数组中。
    例如,当score数组中的数据为10、20、30、40、50、60、70、80、90时,函数返回的人数应该是4,below中的数据应为10、20、30、40。
    ♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
    #include <string.h>
    #include <conio.h>
    #include <stdio.h>
    /*第一个for()循环用来计算score数组中分数的总和,然后用aver/=m求出平均值,第二个循环用来找出小于平均分的元素,并放到数组below中,这里要注意j的递增方式。*/
    int fun(int score[],int m, int below[])
    { int i,j=0,aver=0;
    for(i=0;i<m;i )
    aver =score[i];
    aver/=m;
    for(i=0;i<m;i )
    if(score[i]<aver)
    below[j ]=score[i];
    return j;
    }
    main()
    { int i,n,below[9];
    int score[9]={10,20,30,40,50,60,70,80,90};
    clrscr();
    n=fun(score,9,below);
    printf("\nBelow the average score are :");
    for(i=0;i<n;i ) printf("%4d",below[i]);
    }
    2.请编写函数fun,它的功能是:求出1到1000之内能被7或11整除、但不能同时被7和11整除的所有整数并将它们放在a所指的数组中,通过n返回这些数的个数。
    ♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
    #include <conio.h>
    #include <stdio.h>
    /*该题关键就是如何表示能被7或11整除,但不能同时被7和11整除。用(i%7==0)//(i%11==0)来表示能被7或11整除,用 !((i%7==0)&&(i%11==0))来表示不能同时被7和11整除。
    void fun(int *a,int *n)
    { int i,m=0;
    for(i=1;i<1000;i )
    if(((i%7==0)//(i%11==0))&&!((i%7==0)&&(i%11==0)))
    {a[m]=i;m =1;}
    *n=m;
    } 
    main()
    { int aa[1000],n,k;
    clrscr();
    fun(aa,&n);
    for(k=0;k<n;k )
    if((k 1)%10==0) printf("\n");
    else printf("%d,",aa[k]);
    }
    
    3.请编写函数void  fun(int x,int pp[ ],int  *n),它的功能是:求出能整除x且不是偶数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。例如,若x中的值为30,则有4个数符合要求,它们是1,3,5,15。
    ♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
    #include <conio.h>
    #include <stdio.h>
    /*由于要求的数不能是偶数故编程时从1开始循环而步长为2这样正好保正i永远的奇数。这里也要注意存放结果的数组pp的下标变化方式。*/
    void fun(int x, int pp[], int *n)
    { int i,j=0;
    for( i=1;i<=x; i=i 2)
    if( x%i==0)
    pp[j ]=i;
    *n=j;
    }
    main()
    { int x, aa[1000], n, i;
    printf("\n please enter an integer number:\n"); scanf("%d
    ",&x);
    fun(x,aa,&n);
    for(i=0;i<n;i )
    printf("%d ", aa[i]);
    printf("\n");
    }
    4.请编写一个函数void  fun(char *tt,int pp[]),统计在字符串中‘a’到‘z’26个字母各自出现的次数,并依次放在pp所指数组中。
    例如,当输入字符串abcdefgabcdeabc后,程序的输出结果应该是:3 3 3 2 2 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
    ♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
    #include<conio.h>
    #include<stdio.h>
    /* 34题:本题采用的是字母的ASCII码值与数组pp下标的对应转换关系分别求出对应字母的个数。第一个for()是给pp赋初值0,第二个for()用于控制在字符串内从头到尾移动。由于字母'a'的ASCII码值为97而它的个数要放在pp[0]中,而'a'-97的值正好为0,其它的依此类推。*/
    void fun(char *tt,int pp[])
    { int i;
    for(i=0;i<26;i )
    pp[i]=0;
    for(;*tt;tt )
    if(*tt<='z'&&*tt>='a')
    pp[*tt-97] ;
    } 
    main()
    { char aa[1000];
    int bb[26],k;
    clrscr();
    printf("\nPlease enter a char string:");scanf("%s",aa)
    ;
    fun(aa,bb);
    for(k=0;k<26;k ) printf("%d",bb[k]);
    printf("\n");
    }
    
    5.请编写一个函数void fun(int m,int k,int xx[]),该函数的功能是:将大于整数m且紧靠m 的k个素数存入xx所指的数组中。
    例如,若输入:17,5,则应输出:19,23,29,31,37。    
    ♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
    #include <conio.h>
    #include <stdio.h>
    /*本题中的for()循环用来判断一个数是否为素数,由于个数只能是k个所以用do-while循环来控制。*/
    void fun(int m, int k, int xx[])
    { int i,j=0,p=m 1;
    do
    {for( i=2; i<p; i )
    if(p%i==0) break;
    if(i>=p) xx[j ]=p;
    p ;
    } while(j<k);
    } 
    main()
    { int m,n,zz[1000];
    printf("\n please enter two integers: ");
    scanf("%d%d",&m,&n);
    fun( m,n,zz);
    for(m=0; m<n; m )
    printf("%d ", zz[m]);
    printf("\n");
    }
    
    6.请编写一个函数void fun(char a[],char b[],int n),其功能是:删除一个字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。
    例如,输入一个字符串World,然后输入3,则调用该函数后的结果为Word。
    ♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣♣
    #include <stdio.h>
    #include <conio.h>
    #define   LEN 20
    void fun (char a[ ], char b [ ], int n)
    {
    int i,k=0;
    for(i=0;a[i]!='\0';i )
    if(i!=n)     
    b[k ]=a[i];
    b[k]='\0';      
    }
    main( )
    {
    FILE *wf;
    char strl[LEN], str2[LEN];
    int n ;
    printf ("Enter the string : \n") ;
    gets (strl) ;
    printf ("Enter the position of the string deleted: ") ;
    scanf ("%d", &n) ;
    fun (strl, str2, n) ;
    printf ("The new string is : %s \n", str2) ;
    wf=fopen("out.dat","w");
    fun("world",str2,3);
    fprintf(wf,"%s",str2);
    fclose(wf);
    }
    

 

相关新闻

testtest
上善制度的炼成
新时代呼唤管理理论创新——大卫�梯斯与动态能力理论
创业的不变逻辑
创新管理需要回答的5个问题
十一、弥离
十、转院
九、生机
八、传染
七、求血

您可能对这些感兴趣  

第7讲 综合分析BIM在运用与推广中的障碍问题
考核学生质量的困难
日本福岛核电站事故初步分析
论科技异化与科技人化
中国科技计划项目管理现状与对策
财政科技资金的审计重点和内容
软科学研究机构在政府决策中的功效、困境及对策研究
打造超级DOS系统(下)
DOS命令基础应用(6)
打造超级DOS系统(上)

题目筛选器
日期:
类型:
状态:
得分: <=
分类:
作者:
职业:
关键字:
搜索

 
 
 
  焦点事件
 
  知识体系
 
  职业列表
 
 
  最热文章
 
 
  最多引用文章
 
 
  最新文章
 
 
 
 
网站介绍 | 广告服务 | 招聘信息 | 保护隐私权 | 免责条款 | 法律顾问 | 意见反馈
版权所有 不得转载
沪ICP备 10203777 号 联系电话:021-54428255
  帮助提示    
《我的太学》是一种全新的应用,您在操作中遇到疑问或者问题,请拨打电话13564659895,15921448526。
《我的太学》