2020年MOOCC语言程序设计精髓第十四周编程题练兵

2字符串中的字符排序
题目内容:
编写一个函数,对一个字符串中的字符进行升序排序,并输出字符排序后的字符串,字符串长度小于20。
程序运行结果如下:
Input a string:
friend↙
definr
输入提示信息:“Input a string:\n”
输入格式:
字符串输入采用:gets()函数
输出格式:"%s"

#include 
#include 
#define MAX 20
void Sort_Str(char *str){
    int i,j,len=strlen(str);
    char temp;
    for(i=0;i<len-1;i++){
        for(j=len-1;j>i;j--){
            if(str[j-1]>str[j]){
                temp=str[j-1];
                str[j-1]=str[j];
                str[j]=temp;
            }
        }
    }
}

int main()
{
    char *str;
    str = (char *)malloc(MAX*sizeof(char));
    printf("Input a string:\n");
    gets(str);
    Sort_Str(str);
    printf("%s",str);
    return 0;
}

3纯数字字符串检验
题目内容:
按给定函数原型编程检查一个字符串是否全由数字组成。
int IsAllDigit(char p[]);/若全由数字组成,则函数返回1,否则返回0/
在主函数中,从键盘输入一个字符串(假设字符串的最大长度为20个字符),调用函数IsAllDigit(),检查该字符串是否全由数字组成,然后在主函数中根据函数IsAllDigit()的返回值输出相应的提示信息。
程序运行结果示例1:
Please input a string:
help456↙
The string is not digit string.
程序运行结果示例2:
Please input a string:
20150216↙
The string is digit string.
字符串输入提示信息:“Please input a string:\n”
输入格式: 字符串输入采用 gets()函数
输出格式:
判断是纯数字字符串:“The string is digit string.”
判断不是纯数字字符串:“The string is not digit string.”

#include 
#include 
#define MAX 20

int IsAllDigit(char *str){
    int i;
    for(i=0;str[i]!='\0';i++){
        if(str[i]>'9'||str[i]<'0')
            return 0;
    }
    return 1;
}

int main()
{
    char *str;
    str = (char *)malloc(MAX*sizeof(char));
    printf("Please input a string:\n");
    gets(str);
    if(IsAllDigit(str))
        printf("The string is digit string.");
    else
        printf("The string is not digit string.");
    return 0;
}

4孪生素数
题目内容:
相差为2的两个素数称为孪生素数。例如,3与5,41与43等都是孪生素数。设计程序求出指定区间上的所有孪生素数对。区间上限和下限由键盘获取。
程序运行示例如下:
please input c,d(c>2):
10,200↙
(11,13)
(17,19)
(29,31)
(41,43)
(59,61)
(71,73)
(101,103)
(107,109)
(137,139)
(149,151)
(179,181)
(191,193)
(197,199)
total=13
区间上限和下限的输入提示信息:“please input c,d(c>2):\n”
输入格式:
区间上限和下限的输入格式: “%ld,%ld”
输出格式:
孪生素数的输出格式:"(%ld,%ld)\n"
所有孪生素数对的总数输出格式: “total=%d\n”

#include 
#include 
#define MAX 20

int IsPrime(long number){
    int i;
    for(i=2;i<number;i++){
        if(number%i==0)
            return 0;
    }
    return 1;
}

int main()
{
    long c,d,i;
    int count=0;
    printf("please input c,d(c>2):\n");
    scanf("%ld,%ld",&c,&d);
    for(i=c;i<=d-2;i++){
        if(IsPrime(i)&&IsPrime(i+2)){
            printf("(%ld,%ld)\n",i,i+2);
            count++;
        }
    }
    printf("total=%d\n",count);
    return 0;
}

5求解不等式
题目内容:
对指定正实数n(采用双精度浮点型表示),试求满足下面平方根不等式的最小整数m,并输出不等式左边的值。程序中浮点数的数据类型均为double。
程序运行示例如下:
Input n:
5.1↙
Result:m>=2
s=5.15
输入提示信息:“Input n:\n”
输入格式: “%lf”
输出格式:
整数m的输出格式:“Result:m>=%d\n”
不等式左边的值的输出格式:“s=%.2f\n”

#include 
#include 
#define MAX 20

int IsPrime(long number){
    int i;
    for(i=2;i<number;i++){
        if(number%i==0)
            return 0;
    }
    return 1;
}

int main()
{
    double n,s=0.0;
    int m,i;
    printf("Input n:\n");
    scanf("%lf",&n);
    for(m=0;s<=n;m++){
        s=0.0;
        for(i=m;i<=2*m;i++){
            s+=sqrt(i);
        }
    }
    printf("Result:m>=%d\n",m-1);
    printf("s=%.2f\n",s);
    return 0;
}

你可能感兴趣的:(C语言)