四维数组

#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"); // 输出数组b中每个元素的地址、值 
    for (i = 0; i < N; ++i) 
        printf("%p: %c\n", &b[i], b[i]); 
    printf("\n"); // 输出数组名a和b对应的值 
    printf("a = %p\n", a); 
    printf("b = %p\n", b); 
    return 0; 
}

1.是连续存放的,每个元素占4个内存字节单元

2.是连续存放的,每个元素占1个内存字节单元

3.一样  一样

#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.是,4个

2.是,1个

#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) != 0) // 按下Ctrl+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 n=0;
    int x[12] = {0,31,28,31,30,31,30,31,31,30,31,30};
    if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0))
        x[2] = 29;
    for (int i = 0; i < month; ++i)
        n = n + x[i];
    return n + day;
}
//
// Created by Martin Yang on 2022/5/7.
//

#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;
}
// 输入n个整数保存到整型数组x中
void input(int x[], int n)
{
    int i;
    for(i=0; i<n; ++i)
        scanf("%d", &x[i]);
}
// 输出整型数组x中n个元素
void output(int x[], int n)
{
    int i;
    for(i=0; i<n; ++i)
        printf("%d ", x[i]);
    printf("\n");
}
// 计算整型数组x中n个元素均值,并返回
double average(int x[], int n)
{
    double sum;
    for(int i=0; i<n; ++i)
        sum+=x[i];
    return sum/n;
}
// 对整型数组x中的n个元素降序排序 
void sort(int x[], int n)
{
    int temp;
    for(int i=0;i<N;i++)
    {
        for (int j = N-1; j >= i; --j)
        {
            if (x[j] < x[j + 1])
            {
                temp = x[j + 1];
                x[j + 1] = x[j];
                x[j] = temp;
            }
        }
    }
}
//
// Created by Martin Yang on 2022/5/7.
//

#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;
}// 函数定义 // 功能: 把十进制数x转换成n进制,打印输出 // 补足函数实现
void dec2n(int x, int n)
{
    int a[100]; 
    int count=0;
    do{
        a[count++]=x%n;
        x=x/n;
    }while(x!=0);
    for(int i=count-1;i>=0;i--)
    {
        if (a[i] <= 9)
            printf("%d", a[i]);
        else
            printf("%c", a[i] - 10 + 'A');
    }
    printf("\n");
}
// Created by Martin Yang on 2022/5/7.
//

 

#include <stdio.h>
#define N 100
void Matrix(int x[N][N],int n);
void output(int x[N][N],int n);
int main()
{
    int x[N][N],n;
    while (scanf("%d",&n) !=0){
        Matrix(x,n);
        output(x,n);}
    return 0;
}
void Matrix(int x[N][N],int n)
{
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j) {
            if(i-j>=0)
                x[i][j]=j+1;
            else
                x[i][j]=x[i][j-1];
        }
    }
}
void output(int x[N][N],int n)
{
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j){
            printf("%d", x[i][j]);
        }
        printf("\n");
    }
}
//
// Created by Martin Yang on 2022/5/7.
//

#include <stdio.h> 
#define N 80 
int main() 
{ 
    char views1[N] = "hey, c, i hate u."; 
    char views2[N] = "hey, c, i love u."; 
    char temp;
       int i = 0;
       printf("original views:\n");
       printf("views1: %s\n",views1);
       printf("views2: %s\n",views2);
       while(views1[i]!='\0')
       {
        temp = views1[i];
        views1[i] = views2[i];
        views2[i] = temp;
        i++;
    }
    printf("\nswapping...\n");
    printf("views1: %s\n",views1);
    printf("views2: %s\n",views2);
    return 0;
}

#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)
{
    char t[10];
    for(int i=0;i<n-1;i++)
        for(int j=0;j<n-i-1;j++)
            if (strcmp(str[j], str[j + 1]) > 0)
            {
                strcpy(t, str[j]);
                strcpy(str[j], str[j + 1]);
                strcpy(str[j + 1], t);
            }
}

 

posted @ 2022-05-07 13:31  然而某人还在摸鱼  阅读(814)  评论(2)    收藏  举报