学生成绩管理系统录入部分怎么写

我写的录入和追加分不出来,录入部分得在追加之后才能运行,具体要求都在图片里,我写的代码也在,能不能帮忙修改一下

img

img

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

struct student {
    char num[10];    
    char name[15];   
    int grade_c;     
    int grade_math;  
    int grade_eng;   
    int score;      
};

void create(struct student students[], int num_students) {
    for (int i = 0; i < num_students; i++) {
        printf("请输入学生的学号:");
        scanf("%s", students[i].num);
        
        printf("请输入学生的姓名:");
        scanf("%s", students[i].name);
        
        printf("请输入学生的C语言成绩:");
        scanf("%d", &students[i].grade_c);
        
        printf("请输入学生的数学成绩:");
        scanf("%d", &students[i].grade_math);
        
        printf("请输入学生的英语成绩:");
        scanf("%d", &students[i].grade_eng);
        
        students[i].score = students[i].grade_c + students[i].grade_math + students[i].grade_eng;
    }
}

void show(struct student students[], int num_students) {
    printf("学号\t姓名\tC语言\t数学\t英语\t总分\n");
    for (int i = 0; i < num_students; i++) {
        printf("%s\t%s\t%d\t%d\t%d\t%d\n", students[i].num, students[i].name, students[i].grade_c, students[i].grade_math, students[i].grade_eng, students[i].score);
    }
}

void search(struct student students[], int num_students, char student_num[]) {
    for (int i = 0; i < num_students; i++) {
        if (strcmp(students[i].num, student_num) == 0) {
            printf("学号\t姓名\tC语言\t数学\t英语\t总分\n");
            printf("%s\t%s\t%d\t%d\t%d\t%d\n", students[i].num, students[i].name, students[i].grade_c, students[i].grade_math, students[i].grade_eng, students[i].score);
            return;
        }
    }
    printf("未找到该学生的信息。\n");
}

void add(struct student students[], int *num_students) 
{
    printf("请输入要追加的学生的学号:");
    scanf("%s", students[*num_students].num);

    printf("请输入要追加的学生的姓名:");
    scanf("%s", students[*num_students].name);
    
    printf("请输入要追加的学生的C语言成绩:");
    scanf("%d", &students[*num_students].grade_c);
    
    printf("请输入要追加的学生的数学成绩:");
    scanf("%d", &students[*num_students].grade_math);
    
    printf("请输入要追加的学生的英语成绩:");
    scanf("%d", &students[*num_students].grade_eng);
    
    students[*num_students].score = students[*num_students].grade_c + students[*num_students].grade_math + students[*num_students].grade_eng;
    
    (*num_students)++;
}

void delete_student(struct student students[], int *num_students, char student_num[]) {
    for (int i = 0; i < *num_students; i++) {
        if (strcmp(students[i].num, student_num) == 0) {
            for (int j = i; j < *num_students - 1; j++) {
                strcpy(students[j].num, students[j + 1].num);
                strcpy(students[j].name, students[j + 1].name);
                students[j].grade_c = students[j + 1].grade_c;
                students[j].grade_math = students[j + 1].grade_math;
                students[j].grade_eng = students[j + 1].grade_eng;
                students[j].score = students[j + 1].score;
            }
            (*num_students)--;
            printf("成功删除学生的信息。\n");
            return;
        }
    }
    printf("未找到要删除的学生的信息。\n");
}

void sort(struct student students[], int num_students) {
    for (int i = 0; i < num_students - 1; i++) {
        for (int j = 0; j < num_students - i - 1; j++) {
            if (students[j].score < students[j + 1].score) {
                struct student temp = students[j];
                students[j] = students[j + 1];
                students[j + 1] = temp;
            }
        }
    }
}

int main() {
    struct student students[100];
    int num_students = 0;
    int choice;
    char student_num[10];
    
    while (1) {
        printf("---------------\n");
        printf("1. 录入学生信息\n");
        printf("2. 显示学生信息\n");
        printf("3. 查询学生个人信息\n");
        printf("4. 追加学生信息\n");
        printf("5. 删除学生信息\n");
        printf("6. 按总分排序\n");
        printf("7. 退出系统\n");
        printf("请输入您的选择:");
        scanf("%d", &choice);
        
        switch (choice) {
            case 1:
                create(students, num_students);
                break;
            case 2:
                show(students, num_students);
                break;
            case 3:
                printf("请输入要查询的学生的学号:");
                scanf("%s", student_num);
                search(students, num_students, student_num);
                break;
            case 4:
                add(students, &num_students);
                break;
            case 5:
                printf("请输入要删除的学生的学号:");
                scanf("%s", student_num);
                delete_student(students, &num_students, student_num);
                break;
            case 6:
                sort(students, num_students);
                show(students, num_students);
                break;
            case 7:
                printf("感谢使用学生成绩管理系统,再见!\n");
                return 0;
            default:
                printf("无效的选择,请重新输入。\n");
                break;
        }
    }
    
    return 0;
}


上图

img

代码+优化+注释

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

// 定义一些常量
#define MAX_STUDENTS 100 // 学生的最大数量
#define NUM_LENGTH 10 // 学号的长度
#define NAME_LENGTH 15 // 姓名的长度

// 定义一个结构体类型来描述学生信息
struct student {
    char num[NUM_LENGTH]; // 学号
    char name[NAME_LENGTH]; // 姓名
    int grade_c; // C语言成绩
    int grade_math; // 数学成绩
    int grade_eng; // 英语成绩
    int score; // 总分
};

// 录入学生信息
void create(struct student students[], int num_students) {
    char buffer[100]; // 缓冲区
    for (int i = 0; i < num_students; i++) {
        printf("请输入第%d个学生的信息:\n", i + 1);
        printf("请输入学生的学号:");
        fgets(buffer, sizeof(buffer), stdin); // 输入字符串到缓冲区
        sscanf(buffer, "%s", students[i].num); // 从缓冲区读取字符串到学号
        printf("请输入学生的姓名:");
        fgets(buffer, sizeof(buffer), stdin);
        sscanf(buffer, "%s", students[i].name); // 从缓冲区读取字符串到姓名
        printf("请输入学生的C语言成绩:");
        fgets(buffer, sizeof(buffer), stdin);
        sscanf(buffer, "%d", &students[i].grade_c); // 从缓冲区读取整数到C语言成绩
        printf("请输入学生的数学成绩:");
        fgets(buffer, sizeof(buffer), stdin);
        sscanf(buffer, "%d", &students[i].grade_math); // 从缓冲区读取整数到数学成绩
        printf("请输入学生的英语成绩:");
        fgets(buffer, sizeof(buffer), stdin);
        sscanf(buffer, "%d", &students[i].grade_eng); // 从缓冲区读取整数到英语成绩
        students[i].score = students[i].grade_c + students[i].grade_math + students[i].grade_eng; // 计算总分
    }
}

// 显示学生信息
void show(struct student students[], int num_students) {
    printf("学号\t姓名\tC语言\t数学\t英语\t总分\n");
    for (int i = 0; i < num_students; i++) {
        printf("%s\t%s\t%d\t%d\t%d\t%d\n", students[i].num, students[i].name, students[i].grade_c, students[i].grade_math, students[i].grade_eng, students[i].score);
    }
}

// 查询学生个人信息
void search(struct student students[], int num_students, char student_num[]) {
    for (int i = 0; i < num_students; i++) {
        if (strcmp(students[i].num, student_num) == 0) {
            printf("学号\t姓名\tC语言\t数学\t英语\t总分\n");
            printf("%s\t%s\t%d\t%d\t%d\t%d\n", students[i].num, students[i].name, students[i].grade_c, students[i].grade_math, students[i].grade_eng, students[i].score);
            return;
        }
    }
    printf("未找到该学生的信息。\n");
}

// 追加学生信息
void add(struct student students[], int *num_students) {
    char buffer[100]; // 缓冲区
    printf("请输入要追加的学生的学号:");
    fgets(buffer, sizeof(buffer), stdin); // 输入字符串到缓冲区
    sscanf(buffer, "%s", students[*num_students].num); // 从缓冲区读取字符串到学号
    printf("请输入要追加的学生的姓名:");
    fgets(buffer, sizeof(buffer), stdin);
    sscanf(buffer, "%s", students[*num_students].name); // 从缓冲区读取字符串到姓名
    printf("请输入要追加的学生的C语言成绩:");
    fgets(buffer, sizeof(buffer), stdin);
    sscanf(buffer, "%d", &students[*num_students].grade_c); // 从缓冲区读取整数到C语言成绩
    printf("请输入要追加的学生的数学成绩:");
    fgets(buffer, sizeof(buffer), stdin);
    sscanf(buffer, "%d", &students[*num_students].grade_math); // 从缓冲区读取整数到数学成绩
    printf("请输入要追加的学生的英语成绩:");
    fgets(buffer, sizeof(buffer), stdin);
    sscanf(buffer, "%d", &students[*num_students].grade_eng); // 从缓冲区读取整数到英语成绩
    students[*num_students].score = students[*num_students].grade_c + students[*num_students].grade_math + students[*num_students].grade_eng; // 计算总分
    (*num_students)++; // 学生数量增加1
}

// 删除学生信息
void delete_student(struct student students[], int *num_students, char student_num[]) {
    for (int i = 0; i < *num_students; i++) {
        if (strcmp(students[i].num, student_num) == 0) {
            for (int j = i; j < *num_students - 1; j++) {
                strncpy(students[j].num, students[j + 1].num, NUM_LENGTH); // 复制后面一个学生的学号到当前位置
                strncpy(students[j].name, students[j + 1].name, NAME_LENGTH); // 复制后面一个学生的姓名到当前位置
                students[j].grade_c = students[j + 1].grade_c; // 复制后面一个学生的C语言成绩到当前位置
                students[j].grade_math = students[j + 1].grade_math; // 复制后面一个学生的数学成绩到当前位置
                students[j].grade_eng = students[j + 1].grade_eng; // 复制后面一个学生的英语成绩到当前位置
                students[j].score = students[j + 1].score; // 复制后面一个学生的总分到当前位置
            }
            (*num_students)--; // 学生数量减少1
            printf("成功删除该学生的信息。\n");
            return;
        }
    }
    printf("未找到要删除的该学生的信息。\n");
}

// 按总分排序
void sort(struct student students[], int num_students) {
    for (int i = 0; i < num_students - 1; i++) {
        for (int j = 0; j < num_students - i - 1; j++) {
            if (students[j].score < students[j + 1].score) {
                struct student temp = students[j]; // 使用临时变量交换两个结构体变量
                students[j] = students[j + 1];
                students[j + 1] = temp;
            }
        }
    }
}

// 主函数
int main() {
    struct student students[MAX_STUDENTS]; // 定义一个结构体数组来存储学生信息
    int num_students = 0; // 定义一个变量来记录学生数量
    int choice; // 定义一个变量来记录用户的选择
    char buffer[100]; // 定义一个缓冲区
    char student_num[NUM_LENGTH]; // 定义一个变量来存储要查询或删除的学生的学号
    while (1) {
        printf("---------------\n");
        printf("1. 录入学生信息\n");
        printf("2. 显示学生信息\n");
        printf("3. 查询学生个人信息\n");
        printf("4. 追加学生信息\n");
        printf("5. 删除学生信息\n");
        printf("6. 按总分排序\n");
        printf("7. 退出系统\n");
        printf("请输入您的选择:");
        fgets(buffer, sizeof(buffer), stdin); // 输入字符串到缓冲区
        sscanf(buffer, "%d", &choice); // 从缓冲区读取整数到用户的选择
        switch (choice) { // 使用switch-case语句来处理用户的选择
            case 1: // 录入学生信息
                printf("请输入要录入的学生数量:");
                fgets(buffer, sizeof(buffer), stdin);
                sscanf(buffer, "%d", &num_students); // 从缓冲区读取整数到学生数量
                create(students, num_students); // 调用录入函数
                break;
            case 2: // 显示学生信息
                show(students, num_students); // 调用显示函数
                break;
            case 3: // 查询学生个人信息
                printf("请输入要查询的学生的学号:");
                fgets(buffer, sizeof(buffer), stdin);
                sscanf(buffer, "%s", student_num); // 从缓冲区读取字符串到要查询的学号
                search(students, num_students, student_num); // 调用查询函数
                break;
            case 4: // 追加学生信息
                add(students, &num_students); // 调用追加函数,注意传递指针参数
                break;
            case 5: // 删除学生信息
                printf("请输入要删除的学生的学号:");
                fgets(buffer, sizeof(buffer), stdin);
                sscanf(buffer, "%s", student_num); // 从缓冲区读取字符串到要删除的学号
                delete_student(students, &num_students, student_num); // 调用删除函数,注意传递指针参数
                break;
            case 6: // 按总分排序
                sort(students, num_students); // 调用排序函数
                show(students, num_students); // 调用显示函数
                break;
            case 7: // 退出系统
                printf("感谢使用学生成绩管理系统,再见!\n");
                return 0; // 结束程序
            default: // 无效的选择
                printf("无效的选择,请重新输入。\n");
                break;
        }
    }
    return 0; // 结束程序
}



这个可以用链表
struct Node
{
struct student Current;
struct Node * pNext;
};
这样追加就是找到最后一个节点添加,删除就是找到某个节点指向要删除的那个的next,再释放

基于new bing部分指引作答:
学生成绩管理系统:

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define NMBSCORE 3
const char* kcname[NMBSCORE] = {"语文","数学","英语"};
typedef struct _stNode
{
    int num;        //学号
    char name[20];  //姓名 
    char sex;       //性别
    int age;        //年龄
    int score[NMBSCORE]; //成绩
    struct _stNode* next;
}StNode;
 
 
 
 
//读取文件
StNode* ReadFile(const char* filename, StNode* head)
{
    StNode* node=0, * tmp=0;
    FILE* fp;
    int i;
    if ((fp = fopen(filename, "r")) == 0)
    {
        printf("文件打开失败\n");
        return 0;
    }
    while (!feof(fp))
    {
        node = (StNode*)malloc(sizeof(StNode));
        fscanf(fp, "%d%20s %c%4d", &node->num, node->name, &node->sex, &node->age);
        for (i = 0; i < NMBSCORE; i++)
            fscanf(fp, "%4d", &node->score[i]);
        fscanf(fp, "\n");
        node->next = 0;
        if (head == 0)
        {
            head = node;
            tmp = head;
        }
        else
        {
            tmp->next = node;
            tmp = node;
        }
    }
    fclose(fp);
    return head;
}
 
//录入信息
StNode* Input(StNode* head)
{
    StNode* p, * node;
    int i;
    system("cls");
    node = (StNode*)malloc(sizeof(StNode));
    //录入信息
    printf("请输入学号:");
    scanf("%d", &node->num);
    printf("请输入姓名:");
    scanf("%s", node->name);
    printf("请输入性别:");
    scanf(" %c", &node->sex);
    printf("请输入年龄:");
    scanf(" %d", &node->age);
    for (i = 0; i < NMBSCORE; i++)
    {
        printf("请输入%s成绩:",kcname[i]);
        scanf("%d", &node->score[i]);
    }
    node->next = 0;
 
    if (head == 0)
    {
        head = node;
        //
    }
    else
    {
        p = head;
        while (p->next)
            p = p->next;
        //新建节点
        p->next = node;
    }
    system("pause");
    return head;
}
//显示所有学生信息
void showAll(StNode* head,int flag)
{
    StNode* p;
    int i = 1, j;
    if(flag == 1)
        system("cls");
    p = head;
    while (p)
    {
        printf("学生%d学号:%d\n", i, p->num);
        printf("学生%d姓名:%s\n", i, p->name);
        printf("学生%d性别:%c\n", i, p->sex);
        printf("学生%d年龄:%d\n", i, p->age);
        printf("学生%d的成绩:", i);
        for (j = 0; j < NMBSCORE; j++)
            printf("%s:%d ", kcname[j], p->score[j]);
        printf("\n");
        i++;
        p = p->next;
    }
    system("pause");
}
 
//查询信息
void Find(StNode* head)
{
    int opt;
    StNode* p = head;
    int id, j;
    char name[20] = { 0 };
    system("cls");
    printf("1.按学号查询\n");
    printf("2.按姓名查询\n");
    scanf("%d", &opt);
    switch (opt)
    {
    case 1:
        printf("请输入学号:");
        scanf("%d", &id);
        while (p)
        {
            if (p->num == id)
            {
                printf("学生学号:%d\n", p->num);
                printf("学生姓名:%s\n", p->name);
                printf("学生性别:%c\n", p->sex);
                printf("学生年龄:%d\n", p->age);
                printf("学生成绩:");
                for (j = 0; j < NMBSCORE; j++)
                    printf("%s:%d ",kcname[j], p->score[j]);
                printf("\n");
                break;
            }
            p = p->next;
        }
        if (p == 0)
            printf("查无此人\n");
        break;
    case 2:
        printf("请输入姓名:");
        scanf("%s", name);
        while (p)
        {
            if (strcmp(p->name, name) == 0)
            {
                printf("学生学号:%d\n", p->num);
                printf("学生姓名:%s\n", p->name);
                printf("学生性别:%c\n", p->sex);
                printf("学生年龄:%d\n", p->age);
                printf("学生成绩:");
                for (j = 0; j < NMBSCORE; j++)
                    printf("%s:%d ", kcname[j], p->score[j]);
                printf("\n");
                break;
            }
            p = p->next;
        }
        if (p == 0)
            printf("查无此人\n");
        break;
    }
    system("pause");
}
 
//修改学生信息
void ModInfo(StNode* head)
{
    StNode* node = 0;
    int id, i;
    system("cls");
    printf("请输入需要修改信息的学生学号:");
    scanf("%d", &id);
    node = head;
    while (node)
    {
        if (node->num == id)
            break;
        else
            node = node->next;
    }
    if (node == 0)
        printf("查无此人\n");
    else
    {
        memset(node->name, 0, 20);
        printf("请输入姓名:");
        scanf("%s", node->name);
        printf("请输入性别:");
        scanf(" %c", &node->sex);
        printf("请输入年龄:");
        scanf(" %d", &node->age);
        printf("请输入班级:");
        for (i = 0; i < NMBSCORE; i++)
        {
            printf("请输入%s成绩:", kcname[i]);
            scanf("%d", &node->score[i]);
        }
    }
    system("pause");
}
 
//删除学生信息
void DeleteInfo(StNode* head)
{
    StNode* node, * pre;
    int id, i=0;
    system("cls");
    printf("请输入需要删除信息的学生学号:");
    scanf("%d", &id);
 
    if (head->num == id)
    {
        node = head->next;
        free(head);
        head = node;
        printf("该学生信息已经删除\n");
        system("cls");
        return;
    }
    else
    {
        pre = head;
        node = head->next;
        while (node)
        {
            if (node->num == id)
            {
                pre->next = node->next;
                free(node);
                node = 0;
                printf("该学生信息已经删除\n");
                system("pause");
                return;
            }
            else
            {
                pre = node;
                node = node->next;
            }
        }
        printf("查无此人\n");
        system("pause");
    }
}
 
//学生信息统计
void Tongji(StNode* head)
{
    StNode* node = head;
    char name[20] = { 0 };
    int index = -1;
    int count = 0;
    char ch=0;
    int i=0;
    int minscore, maxscore;
    system("cls");
    printf("请输入需要查询的课程名称:");
    while (1)
    {
        scanf("%s", name);
        for (i = 0; i < NMBSCORE; i++)
        {
            if (strcmp(name, kcname[i]) == 0)
            {
                index = i;
                break;
            }
        }
        if (i < NMBSCORE)
            break;
        else
            printf("没有该课程,请重新输入课程名称:");
    }
    printf("请输入分数段(如60-70):");
    scanf("%d%c%d", &minscore,&ch,&maxscore);
    while (node)
    {
        if (node->score[index] >= minscore && node->score[index] <= maxscore)
        {
            printf("学号:%d,姓名:%s,%s成绩:%d\n", node->num, node->name, kcname[index], node->score[index]);
            count++;
        }
        node = node->next;
    }
    if (count == 0)
        printf("没有满足该条件的学生\n");
    else
        printf("满足条件的学生共%d人\n", count);
    system("pause");
}
 
 
//学生信息排序
StNode* Sort(StNode* head)
{
    StNode* min_pre = NULL;
    StNode* min = head;
    StNode* tmp = head;
    StNode* new_list = NULL;
    StNode* tail_sort = NULL;
    char name[20] = { 0 };
    int i = 0;
    int cho, index, type;
    system("cls");
    printf("1.根据学号排序\n");
    printf("2.根据某门课程成绩排序\n");
    printf("请选择:");
    scanf("%d", &cho);
    if (cho == 2)
    {
        printf("请输入课程名称:");
        while (1)
        {
            scanf("%s", name);
            for (i = 0; i < NMBSCORE; i++)
            {
                if (strcmp(name, kcname[i]) == 0)
                {
                    index = i;
                    break;
                }
            }
            if (i < NMBSCORE)
                break;
            else
                printf("无该课程,请重新输入课程名称:");
        }
    }
 
    printf("1.升序\n");
    printf("2.降序\n");
    scanf("%d", &type);
 
 
    if (NULL == head)    //若链表为空则不用排序
    {
        return NULL;
    }
    if (NULL == head->next)  //若链表中只有一个数,则不用比较
    {
        printf("min is head\n");
        return head;
    }
    
 
    while (head)
    {
        min = head;
        tmp = head;
        while (tmp->next)
        {
            if (cho == 1) //根据学号排序
            {
                if (type == 1 && min->num > tmp->next->num) //升序
                {
                    min = tmp->next;
                    min_pre = tmp;
                }
                else if (type == 2 && min->num < tmp->next->num) //降序
                {
                    min = tmp->next;
                    min_pre = tmp;
                }
            }
            else if (cho == 2) //根据某门课程的成绩排序
            {
                if (type == 1 && min->score[index] > tmp->next->score[index]) //升序
                {
                    min = tmp->next;
                    min_pre = tmp;
                }
                else if (type == 2 && min->score[index] < tmp->next->score[index])//降序
                {
                    min = tmp->next;
                    min_pre = tmp;
                }
            }
 
            
            tmp = tmp->next;
        }
        if (min == head)
        {
            head = head->next;
        }
        else
        {
            min_pre->next = min->next;
            min->next = NULL;
        }
        if (NULL == new_list)    //按照尾插将最小的数组成新的链表
        {
            tail_sort = min;
            new_list = tail_sort;
        }
        else
        {
            tail_sort->next = min;
            tail_sort = min;
        }
    }
    return new_list;
}
 
 
//学生信息保存
void Save(const char* name, StNode* head)
{
    StNode* node;
    FILE* fp;
    int i;
    system("cls");
    if ((fp = fopen(name, "w")) == 0)
    {
        printf("文件打开失败\n");
        system("pause");
        return;
    }
    node = head;
    while (node)
    {
        fprintf(fp, "%d%20s %c%4d", node->num, node->name, node->sex, node->age);
        for (i = 0; i < NMBSCORE; i++)
            fprintf(fp, "%4d", node->score[i]);
        fprintf(fp, "\n");
        node = node->next;
    }
    fclose(fp);
    printf("文件保存成功!\n");
    system("pause");
}
 
int main()
{
    StNode* head = 0;
    int opt = 0;
    int bgo = 1;
    const char* filename = "students.txt";
 
    head = ReadFile(filename, head); //读取文件
    while (bgo)
    {
        system("cls");
        printf("--------------学生信息管理系统---------------|\n");
        printf("|   1.录入学生信息                           |\n");
        printf("|   2.显示所有学生信息                       |\n");
        printf("|   3.学生信息查询                           |\n");
        printf("|   4.学生信息修改                           |\n");
        printf("|   5.学生信息删除                           |\n");
        printf("|   6.学生信息统计                           |\n");
        printf("|   7.学生信息排序                           |\n");
        printf("|   8.学生信息保存                           |\n");
        printf("|   0.退出系统                               |\n");
        printf("----------------------------------------------\n");
        scanf("%d", &opt);
        switch (opt)
        {
        case 0:
            bgo = 0;
            break;
        case 1:
            head = Input(head);
            break;
        case 2:
            showAll(head,1);
            break;
        case 3:
            Find(head);
            break;
        case 4:
            ModInfo(head);
            break;
        case 5:
            DeleteInfo(head);
            break;
        case 6:
            Tongji(head);
            break;
        case 7:
            head = Sort(head);
            showAll(head,0);
            break;
        case 8:
            Save(filename, head);
            break;
        }
    }
    return 0;
}

把代码贴出来 才好改

  • 帮你找了个相似的问题, 你可以看下: https://ask.csdn.net/questions/7693916
  • 我还给你找了一篇非常好的博客,你可以看看是否有帮助,链接:实现一个学生的成绩的录入与查询成绩(不算原创,也不算转载,是根据他人代码改动而来)
  • 除此之外, 这篇博客: 三子棋游戏思路中的 下面的代码每次打印一个数据,打印一个竖线 一行打印完之后换行打印横线。就是除了数据元素,再就是打印棋盘的结构,让我们的棋盘能显现出来。 部分也许能够解决你的问题, 你可以仔细阅读以下内容或跳转源博客中阅读:
  • void DisplayBoard(char borad[ROW][COL], int row, int col)
    {
        int i = 0;
        for (i = 0; i < row; i++)
        {
            int j = 0;
            for (j = 0; j < col; j++)
            {
                printf(" %c ", borad[i][j]);
                if (j < col - 1)
                {
                    printf("|");
                }
            }
            printf("\n");
            if (i < row - 1)
            {
                for (j = 0; j < col; j++)
                {
                    printf("---");
                    if (j < col - 1)
                        printf("|");
                }
                printf("\n");
            }


        }
    }

  • 您还可以看一下 吴刚老师的【吴刚大讲堂】电商视觉的排版与应用方法课程中的 订单页面的表单视觉优化及细节处理方法小节, 巩固相关知识点