zoukankan      html  css  js  c++  java
  • C语言实验报告

    一.实验题目,设计思路,实现方法

    1  实验题目

    11-2 求矩阵各行元素之和(15 分)

    本题要求编写程序,求一个给定的m×n矩阵各行元素之和。

    12-1 统计大写辅音字母(15 分)

    英文辅音字母是除AEIOU以外的字母。本题要求编写程序,统计给定字符串中大写辅音字母的个数。

    13-1 计算两数的和与差(10 分)

    本题要求实现一个计算输入的两数的和与差的简单函数。

    14-1 使用函数实现字符串部分复制(20 分)

    本题要求编写函数,将输入字符串t中从第m个字符开始的全部字符复制到字符串s中。

    15-1 拆分实数的整数与小数部分(15 分)

    本题要求实现一个拆分实数的整数与小数部分的简单函数。

    二.源程序(可只截取最关键的部分)

    11-2 求矩阵各行元素之和(15 分)

    #include <stdio.h>
    #define M 10
    #define N 10

    int main()
    {
    int a[M][N];
    int sum[M];
    int m,n,i,j;

    scanf("%d %d",&m,&n);

    for(i=0;i<m;i++)
    {
    sum[i]=0;
    for(j=0;j<n;j++)
    {
    scanf("%d",&a[i][j]);
    sum[i]+=a[i][j];
    }
    }

    for(i=0;i<m;i++)
    {
    printf("%d ",sum[i]);
    }

    return 0;
    }

    12-1 统计大写辅音字母(15 分)

    #include<stdio.h>
    int main (void)
    {
    int i,k,count;
    char str[80];
    count=0;

    k=0;
    while((str[k]=getchar())!=' ')
    k++;
    str[k]='';

    for(i=0;str[i]!='';i++){
    if((str[i]>='A')&&(str[i]<='Z')&&(str[i]!='A')&&(str[i]!='E')&&(str[i]!='I')&&(str[i]!='U')&&(str[i]!='O'))
    count++;}
    printf("%d ",count);
    return 0;
    }

    13-1 计算两数的和与差(10 分)

    #include <stdio.h>
    
    void sum_diff( float op1, float op2, float *psum, float *pdiff );
    
    int main()
    {
        float a, b, sum, diff;
    
        scanf("%f %f", &a, &b);
        sum_diff(a, b, &sum, &diff);
        printf("The sum is %.2f
    The diff is %.2f
    ", sum, diff);
    	
        return 0; 
    }

    void sum_diff( float op1, float op2, float *psum, float *pdiff )
    {
    float add, sub;
    *psum = op1+ op2;
    *pdiff = op1- op2;
    }

    14-1 使用函数实现字符串部分复制(20 分)

    #include <stdio.h>
    #define MAXN 20
    
    void strmcpy( char *t, int m, char *s );
    void ReadString( char s[] ); /* 由裁判实现,略去不表 */
    
    int main()
    {
        char t[MAXN], s[MAXN];
        int m;
    
        scanf("%d
    ", &m);
        ReadString(t);
        strmcpy( t, m, s );
        printf("%s
    ", s);
    
        return 0;
    }

    void strmcpy( char *t, int m, char *s ){
    int i,j,length;
    length=0;
    while(t[length]!='')
    length++;
    j=0;
    if(m>0&&m<=length){
    for(i=m-1;t[i]!='';i++){
    s[j]=t[i];
    j++;
    }
    s[j]='';
    }
    else
    s[0]='';
    }

    15-1 拆分实数的整数与小数部分(15 分)

    #include <stdio.h>
    
    void splitfloat( float x, int *intpart, float *fracpart );
    
    int main()
    {
        float x, fracpart;
        int intpart;
    
        scanf("%f", &x);
        splitfloat(x, &intpart, &fracpart);
        printf("The integer part is %d
    ", intpart);
        printf("The fractional part is %g
    ", fracpart);
    
        return 0;
    }

    void splitfloat( float x, int *intpart, float *fracpart )
    {
    int s=x;
    *intpart=s;
    *fracpart=x-*intpart;
    }

    三.遇到的问题及解决方法,心得体会

    数组问题有时分不清次序,之后知道可以用for循环输出想要的值;指针可以指向想要的地址,学会后,敲代码就比较方便了。

  • 相关阅读:
    map映射的用法
    相似的字串(hash+二分)
    进制 /字符串 hash
    CF#632 C.Eugene and an array
    2020牛客寒假算法基础集训营6 H-云
    Educational Codeforces Round 80 (Div. 2)
    Codeforces Round #601 (Div. 2)补题
    luogu-单调队列/单调栈专题
    Comet OJ
    Comet OJ
  • 原文地址:https://www.cnblogs.com/k1206/p/8370964.html
Copyright © 2011-2022 走看看