MOOC哈工大2020C语言程序设计精髓练兵区编程题第十周

1 有趣的“回文”检测(4分)

题目内容:

英文中有很多的回文词,回文词的拼法十分有趣,无论是从前往后拼读,还是从后往前拼读,他们的拼法和词义都不变。例如:dad(爸爸),mum(妈妈),noon(中午),eve(前夕),eye(眼睛),pop(流行),deed(行为),level(水平)等。简单地说,“回文”就是指顺读和倒读都一样的字符串。现在请你编程输入一个单词,判断它是否是回文。

提示:

(1)设置两个指针pStart和pEnd,让pStart指向字符串首部,让pEnd指向字符串尾部。

(2)利用循环从字符串两边对指针所指字符进行比较,当对应的两字符相等且两指针未超越对方时,使指针pStart向前移动一个字符位置(加1),使指针pEnd向后移动一个字符位置(减1),一旦发现两字符不等或两指针已互相超越(不可能是回文),则立即停止循环。

(3)根据退出循环时两指针的位置,判断字符串是否为回文。

#define STR_LEN 80
int main()
{
    char str[STR_LEN + 1], *pStart, *pEnd;
    int len, flag = 1;
    printf("Input string:");
    gets(str);
    len = strlen(str);
    pStart = str;
    pEnd = str + len - 1;
    for (int i = 0; i < len / 2 + 1; ++i)
    {
        if(*pStart++ != *pEnd--)
        {
            flag = 0;
            break;
        }
    }
    if(flag)
    {
        printf("Yes!\n");
    }
    else
    {
        printf("No!\n");
    }
    return 0;
}

2 学生成绩管理系统V1.0(4分)

题目内容:

某班有最多不超过30人(具体人数由键盘输入)参加某门课程的考试,用一维数组作函数参数编程实现如下学生成绩管理:

(1)录入每个学生的学号和考试成绩;

(2)计算课程的总分和平均分;

(3)按成绩由高到低排出名次表;

(4)按学号由小到大排出成绩表;

(5)按学号查询学生排名及其考试成绩;

(6)按优秀(90~100)、良好(80~89)、中等(70~79)、及格(60~69)、不及格(0~59)5个类别,统计每个类别的人数以及所占的百分比;

(7)输出每个学生的学号、考试成绩。

#define N 30

void InputRecord(int id[N], float scores[N], int n);

void CalculateTotalAndAverageScoreOfCourse(float scores[N], int n);

void SortInDescendingOrderByScore(int id[N], float scores[N], int n);

void SortInAscendingOrderByNumber(int id[N], float scores[N], int n);

void SearchByNumber(int id[N],float scores[N], int n);

void StatisticAnalysis(float scores[N], int n);

void ListRecord(int id[N],float scores[N], int n);

int main()
{
    int id[N], n, m;
    float scores[N];
    printf("Input student number(n<30):\n");
    scanf("%d",&n);
    while (1)
    {
        printf("Management for Students' scores\n"
               "1.Input record\n"
               "2.Caculate total and average score of course\n"
               "3.Sort in descending order by score\n"
               "4.Sort in ascending order by number\n"
               "5.Search by number\n"
               "6.Statistic analysis\n"
               "7.List record\n"
               "0.Exit\n"
               "Please Input your choice:\n");
        scanf("%d", &m);
        switch (m)
        {
            case 0:
                printf("End of program!");
                return 0;
            case 1:
                InputRecord(id, scores, n);
                break;
            case 2:
                CalculateTotalAndAverageScoreOfCourse(scores, n);
                break;
            case 3:
                SortInDescendingOrderByScore(id, scores, n);
                break;
            case 4:
                SortInAscendingOrderByNumber(id, scores, n);
                break;
            case 5:
                SearchByNumber(id, scores, n);
                break;
            case 6:
                StatisticAnalysis(scores, n);
                break;
            case 7:
                ListRecord(id, scores, n);
                break;
            default:
                printf("Input error!\n");
        }
    }
    return 0;
}

void InputRecord(int id[N], float scores[N], int n)
{
    printf("Input student's ID, name and score:\n");
    for (int i = 0; i < n; ++i)
    {
        scanf("%ld%f", &id[i], &scores[i]);
    }
}

void CalculateTotalAndAverageScoreOfCourse(float scores[N], int n)
{
    float sum = 0;
    for (int i = 0; i < n; ++i)
    {
        sum += scores[i];
    }
    printf("sum=%.0f,aver=%.2f\n", sum, sum / n);
}

void SortInDescendingOrderByScore(int id[N], float scores[N], int n)
{
    int  flag, t2;
    float t1;
    printf("Sort in descending order by score:\n");
    //冒泡排序
    for (int i = 0; i < n; ++i)
    {
        flag = 0;
        for (int j = 0; j < n - 1 - i; ++j)
        {
            if(scores[j] < scores[j + 1])
            {
                //交换分数
                t1 = scores[j];
                scores[j] = scores[j + 1];
                scores[j + 1] = t1;

                //交换ID
                t2 = id[j];
                id[j] = id[j + 1];
                id[j + 1] = t2;

                //冒泡排序优化
                flag = 1;
            }
        }
        if(!flag)
        {
            break;
        }
    }
    for (int k = 0; k < n; ++k)
    {
        printf("%ld\t%.0f\n", id[k], scores[k]);
    }
}

void SortInAscendingOrderByNumber(int id[N], float scores[N], int n)
{
    int  flag, t2;
    float t1;
    printf("Sort in ascending order by number:\n");
    //冒泡排序
    for (int i = 0; i < n; ++i)
    {
        flag = 0;
        for (int j = 0; j < n - 1 - i; ++j)
        {
            if(id[j] > id[j + 1])
            {
                //交换分数
                t1 = scores[j];
                scores[j] = scores[j + 1];
                scores[j + 1] = t1;

                //交换ID
                t2 = id[j];
                id[j] = id[j + 1];
                id[j + 1] = t2;

                //冒泡排序优化
                flag = 1;
            }
        }
        if(!flag)
        {
            break;
        }
    }
    for (int k = 0; k < n; ++k)
    {
        printf("%ld\t%.0f\n", id[k], scores[k]);
    }
}

void SearchByNumber(int id[N],float scores[N], int n)
{
    int number, i, flag = 0;
    printf("Input the number you want to search:\n");
    scanf("%d", &number);
    for (i = 0; i < n; i++)
    {
        if(id[i] == number)
        {
            flag = 1;
            break;
        }
    }
    if(flag)
    {
        printf("%ld\t%.0f\n", id[i], scores[i]);
    }
    else
    {
        printf("Not found!\n");
    }
}

void StatisticAnalysis(float scores[N], int n)
{
    int a, b, c, d, e, f;
    a = b = c = d = e = f = 0;
    float score;
    for (int i = 0; i < n; ++i)
    {
        score = scores[i];
        if(score == 100)
        {
            a++;
        }
        else if(score >= 90 && score < 100 )
        {
            b++;
        }
        else if(score >= 80)
        {
            c++;
        }
        else if(score >= 70)
        {
            d++;
        }
        else if(score >= 60)
        {
            e++;
        }
        else
        {
            f++;
        }
    }
    printf("<60\t%d\t%.2f%%\n", f, (float)(100 * f) / n);
    printf("%d-%d\t%d\t%.2f%%\n" , 60, 69, e, (float)(100 * e) / n);
    printf("%d-%d\t%d\t%.2f%%\n" , 70, 79, d, (float)(100 * d) / n);
    printf("%d-%d\t%d\t%.2f%%\n" , 80, 89, c, (float)(100 * c) / n);
    printf("%d-%d\t%d\t%.2f%%\n" , 90, 99, b, (float)(100 * b) / n);
    printf("%d\t%d\t%.2f%%\n", 100, a,(float)(100 * a) / n);
}

void ListRecord(int id[N],float scores[N], int n)
{
    for (int i = 0; i < n; ++i)
    {
        printf("%ld\t%.0f\n", id[i], scores[i]);
    }
}

3 程序改错——1(4分)

题目内容:

下面程序的功能是,从键盘输入两个字符串,分别存放在字符数组d和s中,通过调用子函数MyStrcat( )将这两个字符串连接起来,并将连接后的字符串存放在字符数组r中,同时输出连接后的字符串。已知每个字符数组的最大长度为80。下面给出的程序存在错误,找到错误的原因后,请修改正确。并按照给出的程序运行结果示例检查你的程序。

已知函数原型:char* MyStrcat(char *dest, char *source);//函数返回连接后的字符串的首地址

#include <stdio.h>
#include <string.h>
int main(void)
{
        char *first, *second, *result;
        printf("Input the first string:\n");
        gets(first);
        printf("Input the second string:\n");
        gets(second);
        result = MyStrcat(first, second);
        printf("The result is : %s\n", result);
        return 0;
}
char* MyStrcat(char *dest, char *source)
{
        int i = 0;
        while (*(dest+i)!='\0')   i++;
        for (; *(source+i)!='\0'; i++)
        {
            *(dest+i) = *(source+i);   
        }
        return dest;
}

修改后

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

#define STR_LEN 80

char* MyStrcat(char *dest, char *source);

int main(void)
{
    char  first[STR_LEN + 1], second[STR_LEN + 1], *result;
    printf("Input the first string:\n");
    gets(first);
    printf("Input the second string:\n");
    gets(second);
    result = MyStrcat(second, first);
    printf("The result is : %s\n", result);
    return 0;
}

char* MyStrcat(char *dest, char *source)
{
    int i = 0;
    while (*(dest+i) != '\0')
        i++;
    for (; *dest != '\0'; i++)
    {
        *(source + i) = *dest++;
    }
    *(source + i) = '\0';
    return source;
}

4 程序改错——2(4分)

题目内容:

下面程序的功能是输出如示例所示形式的数据,目前程序中存在错误,找到错误的原因后,请修改正确,并按照给出的程序运行结果示例检查你的程序。

程序中用到的函数原型如下:

void YH(int a[][ARR_SIZE], int n);

void PrintYH(int a[][ARR_SIZE], int  n);

#include<stdio.h>
#define  ARR_SIZE  5
void  YH(int a[][ARR_SIZE], int  n);
void  PrintYH(int a[][ARR_SIZE], int  n);
int main(void)
{
        int  a[ARR_SIZE][ARR_SIZE];
        YH(a, ARR_SIZE);
        PrintYH(a, ARR_SIZE);
        return 0;
}
void YH(int a[][ARR_SIZE], int n)
{
        int  i, j ;
        for (i=1; i<=n; i++)
        {  
             a[i][1] = 1;
             a[i][i] = 1;
        }
        for (i=3; i<=n; i++)
        {
            for (j=2; j<=i-1; j++)
            {
                 a[i][j] = a[i-1][j-1] + a[i-1][j];
            }       
        }
}
void PrintYH(int a[][ARR_SIZE], int n)
{
        int i , j ;
        for (i=1; i<n; i++)
        {
            for (j=1; j<=i; j++)
            {
                printf("%4d", a[i][j]);
            }
             printf("\n");
        }
}

修改后

#define  ARR_SIZE  5
void  YH(int a[][ARR_SIZE], int  n);
void  PrintYH(int a[][ARR_SIZE], int  n);
int main(void)
{
    int  a[ARR_SIZE][ARR_SIZE];
    YH(a, ARR_SIZE);
    PrintYH(a, ARR_SIZE);
    return 0;
}

void YH(int a[][ARR_SIZE], int n)
{
    int i, j;
    for (i = 1; i < n; i++)
    {
        a[i][1] = 1;
        a[i][i] = 1;
    }
    for (i = 3; i < n; i++)
    {
        for (j = 2; j <= i - 1; j++)
        {
            a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
        }
    }
}
void PrintYH(int a[][ARR_SIZE], int n)
{
    int i, j;
    for (i = 1; i < n; i++)
    {
        for (j = 1; j <= i; j++)
        {
            printf("%4d", a[i][j]);
        }
        printf("\n");
    }
}

5 出售金鱼(4分)

题目内容:

买买提将养的一缸金鱼分五次出售:第一次卖出全部的一半加二分之一条;第二次卖出余下的三分之一加三分之一条;第三次卖出余下的四分之一加四分之一条;第四次卖出余下的五分之一加五分之一条;最后卖出剩下的11条。问原来鱼缸中共有几条鱼?

int main()
{
    float s = 11, i;
    for (i = 4; i > 0; i--)
    {
        s += 1 / (i + 1);
        s *= (i + 1) / i;
    }
    printf("There are %d fishes at first.\n", (int) s);
    return 0;
}

6 找最值(4分)

题目内容:

从键盘任意输入10个整数,用指针变量作函数参数编程计算最大值和最小值,并返回它们所在数组中的位置。函数原型如下所示:

int FindMax(int num[], int n, int *pMaxPos);//函数返回最大值,pMaxPos返回最大值所在的下标

int FindMin(int num[], int n, int *pMinPos);//函数返回最小值,pMaxPos返回最小值所在的下标

#define N 10
//函数返回最大值,pMaxPos返回最大值所在的下标
int FindMax(int num[], int n, int *pMaxPos);

//函数返回最小值,pMaxPos返回最小值所在的下标
int FindMin(int num[], int n, int *pMinPos);

int main()
{
    int num[N], max, min, pMaxPos = 0, pMinPos = 0;
    printf("Input 10 numbers:\n");
    for (int i = 0; i < N; ++i)
    {
        scanf("%d", &num[i]);
    }
    max = FindMax(num, N, &pMaxPos);
    min = FindMin(num, N, &pMinPos);
    printf("Max=%d,Position=%d,Min=%d,Position=%d\n", max, pMaxPos, min, pMinPos);
    return 0;
}

int FindMax(int num[], int n, int *pMaxPos)
{
    int max = num[0];
    for (int i = 1; i < n; ++i)
    {
        if(max < num[i])
        {
            max = num[i];
            *pMaxPos = i;
        }
    }
    return max;
}

int FindMin(int num[], int n, int *pMinPos)
{
    int min = num[0];
    for (int i = 1; i < n; ++i)
    {
        if(min > num[i])
        {
            min = num[i];
            *pMinPos = i;
        }
    }
    return min;
}

7 杨辉三角形(4分)

题目内容:

编程打印具有如下形式的杨辉三角形,其中输出数据的行数n从键盘输入,并且n<=10

#define  ARR_SIZE  10
void  YH(int a[][ARR_SIZE], int  n);
void  PrintYH(int a[][ARR_SIZE], int  n);

int main()
{
    int n, a[ARR_SIZE][ARR_SIZE];;
    printf("Input n (n<=10):\n");
    scanf("%d", &n);
    YH(a, n);
    PrintYH(a, n);
    return 0;
}

void YH(int a[][ARR_SIZE], int n)
{
    int i, j;
    for (i = 1; i <= n; i++)
    {
        a[i][1] = 1;
        a[i][i] = 1;
    }
    for (i = 3; i <= n; i++)
    {
        for (j = 2; j <= i - 1; j++)
        {
            a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
        }
    }
}
void PrintYH(int a[][ARR_SIZE], int n)
{
    int i, j;
    for (i = 1; i <= n; i++)
    {
        for (j = 1; j <= i; j++)
        {
            printf("%4d", a[i][j]);
        }
        printf("\n");
    }
}

8 颠倒句子中的单词顺序(4分)

题目内容:

从键盘输入一个句子(假设字符数小于100个),句子中的单词之间用空格分隔,句子必须以一个标点符号作为结尾,句子开头和末尾标点符号前均没有空格,以回车表示输入结束,请编程颠倒句中的单词顺序并输出。

函数原型:int Inverse(char str1[], char str2[][N])

#define N 101

int Inverse(char str1[], char str2[][N]);

int main()
{
    char str1[N], str2[N][N], s;
    int i;
    printf("Input a sentence:");
    gets(str1);
    s = str1[strlen(str1) - 1];
    i = Inverse(str1, str2);
    for (; i > 0; i--)
    {
        printf("%s ", str2[i]);
    }
    printf("%s%c\n", str2[i], s);
    return 0;
}

int Inverse(char str1[], char str2[][N])
{
    int i = 0, j = 0, k = 0, n = strlen(str1) - 1;
    for (i = 0; i < n; i++)
    {
        if(str1[i] == ' ')
        {
            j++;
            k = 0;
            continue;
        }
        str2[j][k] = str1[i];
        k++;
    }
    return j;
}

 

  • 3
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值