实验4 数组

实验任务1

//task1_1
#include <stdio.h>
#define N 4

int main()
{
    int a[N] = {2, 0, 2, 2};
    char b[N] = {'2', '0', '2', '2'};
    int i;
    
    printf("sizeof(int) = %d\n", sizeof(int));
    printf("sizeof(char) = %d\n", sizeof(char));
    printf("\n");
    
    //输出数组a中每个元素的地址、值
    for (i = 0;i<N; ++i)
        printf("%p: %d\n", &a[i], a[i]);
        
    printf("\n");
    
    //输出数组名a和b对应的值
    printf("a = %p\n", a);
    printf("b = %p\n", b);
    
    return 0; 
 } 

1.int 型数组a,在内存中是连续存放的,每个元素占用1个内存单元

2.char型数组b,在内存中是连续存放的,每个元素占用1个内存单元

3.数组名a对应的值,和&a[0]是一样的

数组名b对应的值,和&b[0]是一样的

//task1_2
#include <stdio.h>
#define N 2
#define M 3

int main()
{
    int a[N][M] = {{1, 2, 3},{4, 5, 6}};
    char b[N][M] = {{'1', '2', '3'},{'4', '5', '6'}};
    int i, j;
    
    //输出二维数组a中每个元素的地址和值
    for(i = 0; i<N; ++i)
       for(j = 0; j<M; ++j)
           printf("%p: %d\n", &a[i][j], a[i][j]);
           
    printf("\n");
    
    //输出二维数组a中每个元素的地址和值
    for(i = 0; i<N; ++i)
       for(j = 0; j<M; ++j)
          printf("%p: %c\n", &b[i][j], b[i][j]);
          
    return 0; 
}

 

1.int型二维数组a,在内存中是“按行连续存放的”,每个元素占用2个内存单元

2.char型二维数组b,在内存中是“按行连续存放的”,每个元素占用1个内存单元

 

实验任务2

//task2
 #include<stdio.h>
int days_of_year(int year, int month, int day); //函数声明
int main()
{
   int year, month,day;
   int days;
   
   while(scanf("%d%d%d", &year, &month,&day) != EOF) // 按下Ctr1+Z终止
   {
      days = days_of_year(year, month, day); // 函数调用
      printf("%4d-%02d-%02d是这一年的第%d天. \n\n",year, month, day, days) ;
   }
return 0;
}

int days_of_year(int year, int month, int day)
{ 
    int s=0,i;
    if(year%4==0&&year%100!=0||year%400==0)
    {

        int a[12]={31,29,31,30,31,30,31,31,30,31,30,31};
        for(i=0;i<month-1;i++)
        s=s+a[i];
        s=s+day;
       
    }
    else
    {
        int a[12]={31,28,31,30,31,30,31,31,30,31,30,31};
        for(i=0;i<month-1;i++)
        s=s+a[i];
        s=s+day;
    }
    return s;
} 

//task3
#include <stdio.h>
#define N 5

void input(int x[],int n);
void output(int x[],int n);
double average(int x[],int n);
void sort(int x[],int n);

int main()
{
    int scores[N];
    double ave;
    
    printf("录入%d个分数:\n", N);
    input(scores, N);
    
    printf("\n输出课程分数: \n");
    output(scores, N);
    
    printf("\n课程分数处理:计算均分、排序...\n");
    ave = average(scores, N);
    sort(scores, N);
    
    printf("\n输出课程均分: %.2f\n", ave);
    printf("\n输出课程分数(高->低):\n");
    output(scores, N);
    
    return 0;
}


void input(int x[],int n)
{
    int i;

    for(i=0; i<n; ++i)
         scanf("%d",&x[i]);
}

void output(int x[],int n)
{
      int i;

      for(i=0; i<n; ++i)
      printf("%d ",x[i]);

     printf("\n");
}

double average(int x[],int n)
{
    int sum=0,i;
    double ave;
    for(i=0;i<n;i++)
        sum=sum+x[i];
    ave=sum*1.0/N;
    return ave;
}

void sort(int x[],int n)
{
    int i,j,t;
    for(j=1;j<n;j++)
    {
        for(i=0;i<n;i++)
        {
            if(x[i]<x[i+1])
            {
                t=x[i];
                x[i]=x[i+1];
                x[i+1]=t;
            }
        }
     } 
}

实验任务4

//task4
#include <stdio.h>

void dec2n(int x,int n); //函数声明

int main()
{
   int x;

    printf("输入一个十进制整数: ");
    scanf("%d",&x);

    dec2n(x,2); // 函数调用:把x转换成二进制输出
    dec2n(x,8); // 函数调用:把x转换成 八进制输出
    dec2n(x,16); //函数调用:把x转换成十六进制输出

return 0;
}

void dec2n(int x,int n)
{
    char a[100];
    int i,k,j=0;
    for(i=0;x!=0;i++,j++)
    {
        k=x%n;
        if(k>=10)
            a[i]='A'+k-10;
        else
            a[i]='0'+k;
        x=x/n;
    }
    
    for(i=j-1;i>=0;i--)
    printf("%c",a[i]);
    printf("\n");
}

实验任务5

//task5
#include<stdio.h>
#define N 30
int main()
{
    int a[N][N];
    int n;
    int i, j, k;
    printf("Enter n: ");
    while(scanf("%d",&n)!=EOF)
    {
        for (i = 0; i < n; i++)
        {
           for (j = 0; j < n; j++)
            {
              if(i<j)
              {
                a[i][j]=i+1;
              }
              else
              {
                a[i][j]=j+1;
              }
            }
        }
    for (i=0;i<n;i++)
    {
        for (j=0;j<n;j++)
            printf("%d ", a[i][j]);
        printf("\n");
    }
    printf("\nEnter n: ");
    }
   
    return 0;
}

实验任务6

//task6
#include <stdio.h>
#define N 80

int main()
{
    int i,j;
    char t;
    char views1[N]="hey,c,i hate u.";
    char views2[N]="hey,c,i love u.";
    
    printf("otiginal views:\n");
    printf("views1:");
    for(i=0;i<N;i++)
    printf("%c",views1[i]);
    printf("\nviews2:");
    for(j=0;j<N;j++)
    printf("%c",views2[j]);
    printf("\n\n");
    
    printf("swapping...\n\n");
    
    for(i=0;i<N;i++)
    for(j=0;j<N;j++)
    if(i=j)
    {
        t=views1[i];
        views1[i]=views2[i];
        views2[i]=t;
    }
    
    printf("views1:");
    for(i=0;i<N;i++)
    printf("%c",views1[i]);
    printf("\nviews2:");
    for(j=0;j<N;j++)
    printf("%c",views2[j]);
    printf("\n");
    
    return 0;
}

实验任务7

//task7
#include <stdio.h>
#include <string.h>

#define N 5
#define M 20

void bubble_sort(char str[][M],int n);

int main()
{
    char name[][M]={"Bob","Bill","Joseph","Taylor","George"};
    int i;
    
    printf("输出初始名单:\n");
    for(i=0;i<N;i++)
          printf("%s\n",name[i]);
    
    printf("\n排序中...\n");
    bubble_sort(name,N);
    
    printf("\n按字典序输出名单:\n");
    for(i=0;i<N;i++)
          printf("%s\n",name[i]);
    
    return 0;
}

void bubble_sort(char str[][M],int n)
{
    int j,i;
    char t[10];
    for(j=1;j<n;j++)
    {
        for(i=0;i<n-j-1;i++)
        {
            if(strcmp(str[i],str[i+1])>0)
            {
            strcpy(t,str[i]);
            strcpy(str[i],str[i+1]);
            strcpy(str[i+1],t);
            }
        }
    }
}

 

posted @ 2022-05-09 23:53  阁下-  阅读(32)  评论(2)    收藏  举报