C程序设计实验报告

 

姓   名:张美盛  
实验地点:家                      
实验时间:2020年5月7日                 
实验项目:一维数组的运用

                 二维数组的应用

                 字符数组的应用

 

 

一、实验目的与要求

1、掌握一维和多维数组的定义和数组元素的引用方法。

2、了解一维和多维数组初始化方法。

3、学习一维和多维数组的基本算法。

4、掌握数组的定义、初始化方法及其元素的引用方法。

5、掌握c语言提供的对字符串进行处理的基本函数库。

 

二、实验内容

一维数组的应用(7.3.1)
实验练习1:(1)问题的简单描述:编写程序,利用随机函数产生的10个数,按升序排序输出。

 

实验代码:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void sort1(int s[],int n)
{
    int i,j;
    int temp;
    for(i=0 ;i<n-1;i++)
    for(j=9;j>=i+1;j--)
        if(s[j]<s[j-1])
        {
        temp=s[j];
        s[j]=s[j-1];
        s[j-1]=temp;
        }
        
}
main()
{
    int i,a[10];
    srand(time(NULL));
    printf("随机产生10个整数:\n");
    for(i=0;i<10;i++)
        a[i]=rand()%100;
    for(i=0;i<10;i++)
        {
        printf("%d",a[i]);
        printf(" ");
        }
        printf("\n");
        sort1(a ,10);
        printf("排序后的结果:\n");
    for(i=0;i<10;i++)
        {
        printf("%d",a[i]);
        printf(" ");
        }
}

(3)问题分析给出的随机种子要用到srand(time(null))函数,数组函数的调用是直接调用sort1(a,10)

 

实验二:对随机产生的10个随机整数从大到小的顺序排列

实验代码

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void sort2(int s[],int n)
{
    int i,j,k;
    int temp;
    for(i=0;i<n-1;i++)
    {
        for(j=i+1;j<=n-1;j++)
        {
        if(s[j]<s[i])
            {
            temp=s[i];
            s[i]=s[j];
            s[j]=temp;
            }
        }
    }
}
main()
{
    int i,a[10];
    srand(time(NULL));
    printf("随机产生10个整数:\n");
    for(i=0;i<10;i++)
    a[i]=rand( )%100;
    for(i=0;i<10;i++)
    {
    printf("%d",a[i]);
    printf(" ");
    }
    printf("\n");
    sort2(a ,10);
    printf("排序后的结果:\n");
    for(i=0;i<10;i++)
    {
    printf("%d",a[i]);
    printf(" ");
    }
}

(3)问题分析:无

 

 

二维数组的运用(7.3.2)

(1)问题的简单描述:编写程序,从键盘输入行数,输出指定函数的杨辉三角形。

实验代码

#include<stdio.h>
main()
{
    int a[50][50],i,j,n;
    printf("请输入杨辉三角的行数:");
    scanf("%d",&n);
    for(i=0;i<=n;i++)
    {
        a[i][i]=1;
        a[i][0]=1;
    }
    for(i=2;i<n;i++)
    {
      for(j=1;j<=i-1;j++)
       {
         a[i][j]=a[i-1][j-1]+a[i-1][j];
       }
    }
    for(i=0;i<=n;i++)
    {
        for(j=0;j<=i;j++)
        {
            printf(" ");
            printf("%d",a[i][j]);    
        }
        printf("\n");

    }
}

 

(3)问题分析:比较难以理解

版权声明:本文为meisheng原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/meisheng/p/12843771.html