C语言基础习题50例(七)31-35

CuterCorley
• 阅读 1629

C语言基础习题50例(七)31-35 喜提头条号黄V,有兴趣的朋友可以关注一波,主写IT领域。

习题31

请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

实现思路: 使用switch语句,如果第1个字母一样,则判断用情况语句或if语句判断第2个字母。 也可以使用条件判断语句,实现相近。

代码如下:

#include<stdio.h>

int main(){
    char i, j;
    printf("请输入一个字母:\n");
    i = getchar();
    getchar();
    switch(i){
        case 'M':
            printf("今天是星期一");
            break;
        case 'T':
            printf("请输入第二个字母:\n");
            j = getchar();
            switch(j){
                case 'u':
                    printf("今天是星期二");
                    break;
                case 'h':
                    printf("今天是星期四");
                default:
                    printf("输入错误");
                    break;  
            }
            break;
        case 'W':
            printf("今天是星期三");
            break;
        case 'F':
            printf("今天是星期五");
            break;
        case 'S':
            printf("请输入第二个字母:\n");
            j = getchar();
            switch(j){
                case 'a':
                    printf("今天是星期六");
                    break;
                case 'u':
                    printf("今天是星期天");
                break;
                default:
                    printf("输入错误");
                    break;
            }
            break;
        default:
            printf("输入错误");
            break;
    }

    return 0;
}

打印:

请输入一个字母:
S
请输入第二个字母:
a
今天是星期六

输入第一个字母之后,又输入了回车,所以需要有一个getchar()函数来接收输入的换行符,后面才能接收到新输入的字符。

习题32

删除一个字符串中的指定字母,如:字符串ACA,删除其中的一个字母。

实现思路: 逐个遍历字符并判断。

代码如下:

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

int main(){
    char originStr[256];
    char ch;
    int i = 0, j = 0;
    printf("Please input a string:\n");
    ch = getchar();
    while(ch != '\n'){
        originStr[i++] = ch;
        ch = getchar();
    }
    printf("Please input the character to delete:\n");
    ch = getchar();
    for(i = 0; i < strlen(originStr); i++){
        if(ch != originStr[i]){
            originStr[j++] = originStr[i];
        }
    }
    originStr[j] = '\0';
    printf("New String is:\n%s\n", originStr);

    return 0;
}

打印:

Please input a string:
I like programming!!
Please input the character to delete:
i
New String is:
I lke programmng!!

习题33

判断一个数是否为质数。

实现思路: 抽离用函数实现。

代码如下:

#include <stdio.h>
#include <math.h>

int main(){
    int isPrime(int n);
    int num;
    printf("Please input a number:\n");
    scanf("%d", &num);
    int result = isPrime(num);
    if(result){
        printf("%d is a prime number\n", num);
    }
    else{
        printf("%d is not a prime number\n", num);
    }

    return 0;
}

int isPrime(int n){
    int i, prime = 1;
    for(i = 2; i <= sqrt(n); i++){
        if(n % i == 0){
            prime = 0;
        }
    }

    return prime;
}

打印:

Please input a number:
125
125 is not a prime number

习题34

实现函数的多层调用。

实现思路: 多层调用即可。

代码如下:

#include <stdio.h>

int main(){
    void hello_3();
    hello_3();

    return 0;
}

void hello_3(){
    void hello(int n);
    int i;
    for(i = 0; i < 10; i++){
        hello(i);
    }
}

void hello(int n){
    printf("%d.Hello World!!!\n", n);
}

打印:

0.Hello World!!!
1.Hello World!!!
2.Hello World!!!
3.Hello World!!!
4.Hello World!!!
5.Hello World!!!
6.Hello World!!!
7.Hello World!!!
8.Hello World!!!
9.Hello World!!!

习题35

字符串反转,如将字符串blog.csdn.net/CUFEECR反转为RCEEFUC/ten.ndsc.golb

实现思路: 使用指针实现,即交换字符串中字符的指针。

代码如下:

#include <stdio.h>

 int main(){
    void reverse(char* s);
    char s[] = "I love C";
    printf("%s =>\n", s);
    reverse(s);
    printf("%s\n", s);
    return 0;
}

void reverse(char* s){
    int len = 0;
    char* p = s;
    while (*p != 0){
        len++;
        p++;
    }

    int i = 0;
    char c;
    while (i <= len / 2 - 1){
        c = *(s + i);
        *(s + i) = *(s + len - 1 - i);
        *(s + len - 1 - i) = c;
        i++;
    }
}

打印:

I love C =>
C evol I

本文原文首发来自博客专栏C语言实战,由本人转发至https://www.helloworld.net/p/gRDSa3hzOF2P,其他平台均属侵权,可点击https://blog.csdn.net/CUFEECR/article/details/106626151查看原文,也可点击https://blog.csdn.net/CUFEECR浏览更多优质原创内容。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解
Opencv中Mat矩阵相乘——点乘、dot、mul运算详解2016年09月02日00:00:36 \牧野(https://www.oschina.net/action/GoToLink?urlhttps%3A%2F%2Fme.csdn.net%2Fdcrmg) 阅读数:59593
Stella981 Stella981
3年前
Linux查看GPU信息和使用情况
1、Linux查看显卡信息:lspci|grepivga2、使用nvidiaGPU可以:lspci|grepinvidia!(https://oscimg.oschina.net/oscnet/36e7c7382fa9fe49068e7e5f8825bc67a17.png)前边的序号"00:0f.0"是显卡的代
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Stella981 Stella981
3年前
Nginx反向代理upstream模块介绍
!(https://oscimg.oschina.net/oscnet/1e67c46e359a4d6c8f36b590a372961f.gif)!(https://oscimg.oschina.net/oscnet/819eda5e7de54c23b54b04cfc00d3206.jpg)1.Nginx反
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这