字符串(2)

4.字符串的常见函数

代码

复制代码
#include <stdio.h>
#include <string.h>
int main()
{
        char* str1 = "abc";
        char str2[100] = "abc";
        char str3[5] = { 'q','w','e','r' ,'\0' };


        printf("---------------------strlen(长度)---------------------------\n");
        ////细节:strlen这个函数在统计长度的时候,是不计算结束标记的
        ////细节:在window中,默认情况下,一个中文占2个字节
        //int len1 = strlen(str1);//3
        //int len2 = strlen(str2);//3
        //int len3 = strlen(str3);//4
        ////想要调用这个函数,直接把对应的字符串直接传递给他就行了,这个函数会给我们返回一个整数,就是当前字符串的长度

        //printf("%d\n", len1);
        //printf("%d\n", len2);
        //printf("%d\n", len3);
       第一个数组要留足够的位置,因为要拼接第二个数组的内容,也需要位置


        printf("---------------------strcat(拼接)---------------------------\n");
        ////细节:把第二个字符串中全部的内容,拷贝到 第一个字符串的末尾
        //       //前提1:第一个字符串的内容是可以被修改的
        //       //前提2:第2个字符串中剩余的空间可以容纳拼接的字符串
        //strcat_s(str2, str3);//abcqwer
        //printf("%s\n", str2);//qwer
        //printf("%s\n", str3);

        ////现在是把str2和str3给传递过去了,也就是说现在要把qwer拼在abc后面


        printf("---------------------strcpy(拷贝)---------------------------\n");

        //strcat_s(str2, sizeof(str2), str3);
        ////细节:把第2个字符串所有的内容,拷贝到第一个字符串中,把第一个字符串里面原有的内容给覆盖了
        ////     前提1:第一个字符串是可以被修改的
        ////     前提2:第一个字符串中空间可以容纳第二个字符串的完整内容

        //printf("%s\n", str2);//qwer
        //printf("%s\n", str3);//qwer



        printf("---------------------strcmp(比较)---------------------------\n");
        //细节:在比较的时候,要求顺序和内容完全一样,才叫做字符串一样
        ////完全一样:0
        ////只要有一个不一样:非0
        //int res = strcmp(str1, str2);
        //printf("%d\n", res);




        //printf("---------------------strlwr(变小写)---------------------------\n");
        //细节:只能转换英文的大小写,不能修改中文的大小写------1壹
        //_strlwr(str2) ;
        //printf("%s\n",str2);






        //printf("---------------------strupr(变大写)---------------------------\n");
        //细节:只能转换英文的大小写,不能修改中文的大小写
        _strupr_s(str2, sizeof(str2));
        printf("%s\n",str2);

        return 0;
}

5.用户登陆

复制代码
#include <stdio.h>
#include<string.h>
int main()
{
        /*
        需求:已知正确的用户名和密码,请用程序实现模拟用户登陆
        总共给3次机会,登录之后,请给出提示
        
        
        */

        //1.定义两个变量表示正确的用户名和密码
        char* rightUsername = "zhangtao";
        char* rightPassword = "1234qwer";

        

        //3.比较
        for (int i = 1; i <= 3; i++)
        {

                //2.键盘录入2个字符串,表示用户输入的用户名和密码
                printf("请输入用户名\n");
                char username[100];
                scanf("%s", username);

                printf("请输入密码\n");
                char password[100];
                scanf("%s", password);


                //验证
                printf("%s\n", username);
                printf("%s\n", password);

                if (!strcmp(username, rightUsername) && !strcmp(password, rightPassword))
                {
                        printf("登录成功\n");
                        break;
                }

                else
                {
                        if (i == 3)
                        {
                                printf("用户%s被锁定,请联系黑马程序员官方账号",username);
                        }


                        else
                        {
                                printf("登录失败,还剩下%d次机会\n", 3 - i);
                        }
                }



        }





        return 0;



}

6.统计次数

复制代码
#include <stdio.h>
#include<string.h>
int main()
{
        /*
             键盘录入一个字符串,统计该字符串中大写字母字符,小写字母字符,数字字符出现的次数
                 (不考虑其他字符)
        */

        //1.键盘录入一个字符串
        printf("请输入一个字符串\n");
        char str[100];
        scanf_s("%s", str);

        //2.统计该字符中大写字母字符,小写字母字符,数字字符出现的次数
        //遍历字符串得到了吗的每一个字符

        int bigcount = 0;
        int smallcount = 0;
        int numbercount = 0;

        for (int i = 0; i < strlen(str); i++)
        {
                char c = str[i];
                if(c>='a' && c<='z')
                {
                        smallcount++;
                }
                else if (c >= 'A' && c <= 'Z')
                {
                        bigcount++;
                }
                else if (c >= '0' && c <= '9')
                {
                        numbercount++;
                }
        }

        printf("大写字符出现了%d次\n", bigcount);
        printf("小写字符出现了%d次\n", smallcount);
        printf("数字字符出现了%d次\n", numbercount);












        return 0;



}

错误

数组名不能直接赋值

输入一行字符,统计其中有多少个单词,单词之间用空格分隔开

复制代码
if(c=='')//word新单词出现标志,word=0,一般出现空格就要换到另一个新单词
word=0;
else if(word==0)
{
word =1;//表示这是新单词
num++;//遇到非空格就回++,而前面是空格

#include <stdio.h>
int main()
char string[81],c;
int i,num=0;word=0;
gets(string);//不用scanf,不能录入空格
for(i;(c=string[i])!='\0';i++)
if(c=='')
word=0;
else if(word==0)
{word=1;
num++;
}
printf("%d words\n",num);
return 0;
相关推荐
快去睡觉~3 小时前
力扣152:乘积最大子数组
算法·leetcode·职场和发展
程序员Xu3 小时前
【LeetCode热题100道笔记】二叉树的中序遍历
笔记·算法·leetcode
地平线开发者3 小时前
理想汽车智驾方案介绍 4 | World model + 强化学习重建自动驾驶交互环境
算法·自动驾驶
石氏是时试4 小时前
拉格朗日多项式
人工智能·算法·机器学习
二哈不在线4 小时前
代码随想录二刷之“贪心算法”~GO
算法·贪心算法·golang
快去睡觉~4 小时前
力扣416:分割等和子集
数据结构·c++·算法·leetcode·职场和发展·动态规划
仙俊红4 小时前
LeetCode每日一题,2025-9-5
算法·leetcode·职场和发展
阿维的博客日记4 小时前
LeetCode 240: 搜索二维矩阵 II - 算法详解(秒懂系列
算法·leetcode·矩阵
小O的算法实验室5 小时前
2024年ASOC SCI2区TOP,有效离散人工蜂群算法+变压器制造矩形切割问题,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进