当前位置: 首页 > news >正文

天空网站开发者/网络推广服务费

天空网站开发者,网络推广服务费,政府网站信息内容建设责任制,258做网站靠谱么1.字符串输入函数 scanf("%s",数组名)&#xff1b; gets(数组名)&#xff1b; 区别&#xff1a; scanf(“%s”,数组名); 把空格识别为输入结束 #include <stdio.h>int main() {char a[10];printf("输入&#xff1a;");scanf("%s",a)…

1.字符串输入函数

scanf("%s",数组名);

gets(数组名);

区别:

scanf(“%s”,数组名);  把空格识别为输入结束

#include <stdio.h>int main()
{char a[10];printf("输入:");scanf("%s",a);//gets(a);printf("输出:%s\n",a);return 0;
}

gets(数组名);  可以识别空格字符到数组中

#include <stdio.h>int main()
{char a[10];printf("输入:");//scanf("%s",a);gets(a);printf("输出:%s\n",a);return 0;
}

2.字符串输出函数

printf(“xxxx%s”,数组名);

puts(数组名);

区别:

printf可以放描述语

puts函数自动加换行符

3.计算字符串有效长度函数

计算字符串长度可以使用标准库中的 strlen 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() 
{char str[] = "Hello, World!";size_t length = strlen(str);  // 计算字符串长度printf("Length of the string is: %zu\n", length);return 0;
}

sizeof   和  strlen 的区别?

sizeof:

属性 :是一个关键字

使用格式: int val = sizeof(变量名); 可以用于变量,数组

功能    :计算占用字节空间大小的

strlen:

属性 :是一个函数

使用格式: int val = strlen(数组名) ;只能用于数组(字符串)

功能    :计算字符串的有效长度

练习1:

char a[10] = “qwert”;

sizeof(a)    //10byte

strlen(a)    //5

练习2:

char a[] = “qwert”;

sizeof(a)    //6byte   

strlen(a)    //5

练习:自己写一个。

要求:

用户在主函数中输入一个字符串,

写一个子函数,子函数功能是接到主函数的字符串计算长度,并且返回具体长度值.

主函数调用子函数通过接收返回值来打印字符串的长度.

#include <stdio.h>int my_strlen(char *str);int main()
{char a[20];int len;printf("请输入一个字符串:\n");scanf("%s",a);len = my_strlen(a);printf("输入的字符串的长度为:%d",len);return 0;
}/*******************************************************
函数名     :my_strlen
函数功能   :计数字符串的有效长度
函数参数   :char *str
函数返回值 :int
函数描述   :
*******************************************************/
int my_strlen(char *str)
{int cont = 0;int i = 0;while(*(str+i) != '\0'){cont++;i++;}return cont;
}

4.字符串复制函数

复制字符串可以使用标准库中的 strcpy 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() {char src[] = "Hello, World!";char dest[50];  // 确保目标数组足够大strcpy(dest, src);  // 复制字符串printf("Source String: %s\n", src);printf("Destination String: %s\n", dest);return 0;
}

练习:自己写一个。

要求:

        用户输入两个字符串str1 和 str2

        要求写一个子函数将str2复制给str1

        打印复制后的str1

         char str1[] = “123456”;     

         char str2[] = “abcdef“;

        复制后:str1 : “abcdef“  

#include <stdio.h>void my_strcpy(char *dest,char *src);int main()
{char str1[50],str2[50];printf("请输入str1:");scanf("%s",str1);printf("请输入str2:");scanf("%s",str2);my_strcpy(str1,str2);printf("复制后的str1:%s",str1);return 0;
}/*******************************************************
函数名     :my_strcpy
函数功能   :复制字符串
函数参数   :char *dest char *src
函数返回值 :无
函数描述   :函数会将字符串src复制给dest
*******************************************************/
void my_strcpy(char *dest,char *src)
{int i = 0;while(*(src+i) != '\0'){*(dest+i) = *(src+i);i++;}*(dest+i) = '\0';       //这句非常重要,否则当str1和str2长度不一致时会出现bug
}

假如没有加这一句:

*(dest+i) = '\0';

当str2长, str1短,  复制后str1会出现乱码,因为结束字符被覆盖了;(有些编译器在执行时会优化,不会出现乱码)

当str1长, str2短,  复制后str1会没有完全被覆盖;

可以注释掉这一句看看会发生什么。

5.字符串拼接函数 

字符串拼接可以使用标准库中的 strcat 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() {char dest[50] = "Hello, ";  // 目标字符串,留出足够空间char src[] = "World!";// 使用 strcat 函数拼接字符串strcat(dest, src);printf("Concatenated String: %s\n", dest);return 0;
}

练习:自己写一个。

要求:

用户主函数中输入两个字符串str1和str2

写一个子函数实现将str2拼接到str1后面

str1:1234

str2:abcd

拼接后:str1:1234abcd

#include <stdio.h>void my_strcat(char *dest,char *src);int main()
{char str1[50],str2[50];printf("请输入str1:");scanf("%s",str1);printf("请输入str2:");scanf("%s",str2);my_strcat(str1,str2);printf("拼接后的str1:%s",str1);return 0;
}/*******************************************************
函数名     :my_strcat
函数功能   :拼接字符串
函数参数   :char *dest char *src
函数返回值 :无
函数描述   :函数会将字符串src拼接在dest后
*******************************************************/
void my_strcat(char *dest,char *src)
{int i = 0,j = 0;while(*(dest+i) != '\0'){i++;}while(*(src+j) != '\0'){*(dest+i) = *(src+j);i++;j++;}*(dest+i) = '\0';
}

6.字符串比较函数

字符串比较可以使用标准库中的 strcmp 函数。这个函数位于 <string.h> 头文件中。

#include <stdio.h>
#include <string.h>int main() {char str1[50], str2[50];printf("请输入第一个字符串: ");scanf("%s", str1);printf("请输入第二个字符串: ");scanf("%s", str2);int result = strcmp(str1, str2);if (result == 0) {printf("两个字符串相同。\n");} else if (result < 0) {printf("第一个字符串小于第二个字符串。\n");} else {printf("第一个字符串大于第二个字符串。\n");}return 0;
}

(库函数是从头开始逐个比较,只要出现不同的字符就立马返回结果) 

练习:自己写一个。

要求:

用户在主函数输入两个字符串,str1和str2,

在子函数中判断连个字符串是否相等,(长度要相等,对应字符一样)

相等返回0,不相等返回1;

(和库函数不太一样)

#include <stdio.h>int my_strcmp(char *str1,char *str2);int main()
{char str1[50],str2[50];int judge;printf("请输入str1:");scanf("%s",str1);printf("请输入str2:");scanf("%s",str2);judge = my_strcmp(str1,str2);if(judge == 0){printf("字符串str1和字符串str2相同。");}else if(judge == 1){printf("字符串str1和字符串str2不相同。");}return 0;
}/*******************************************************
函数名     :my_strcmp
函数功能   :比较字符串
函数参数   :char *str1 char *str2
函数返回值 :int
函数描述   :比较字符串str1和字符串str2,如果相同则返回0,不相同则返回1.(长度和内容都相同)
*******************************************************/
int my_strcmp(char *str1, char *str2)
{// 定义循环索引变量int i = 0, j = 0, k = 0;// 遍历第一个字符串,找到结束符'\0'的位置while (*(str1 + i) != '\0'){i++;  // 递增索引}// 遍历第二个字符串,找到结束符'\0'的位置while (*(str2 + j) != '\0'){j++;  // 递增索引}// 如果两个字符串的长度相同if (i == j){// 比较两个字符串的每一个字符while (*(str1 + k) != '\0'){// 如果某一位置的字符不同,返回1表示不相同if (*(str1 + k) != *(str2 + k)){return 1;  // 字符不同,返回1}k++;  // 继续比较下一个字符}return 0;  // 所有字符都相同,返回0}else  // 如果两个字符串的长度不同{return 1;  // 长度不同,返回1}
}

也可以这样写,这样比较像库函数的写法。

#include <stdio.h>int my_strcmp(char *str1, char *str2);int main()
{char str1[50], str2[50];int judge;printf("请输入str1: ");scanf("%s", str1);printf("请输入str2: ");scanf("%s", str2);judge = my_strcmp(str1, str2);if(judge == 0){printf("字符串str1和字符串str2相同。\n");}else{printf("字符串str1和字符串str2不相同。\n");}return 0;
}/*******************************************************
函数名     : my_strcmp
函数功能   : 比较字符串
函数参数   : char *str1, char *str2
函数返回值 : int
函数描述   : 比较字符串str1和字符串str2,如果相同则返回0,不相同则返回1。(长度和内容都相同)
*******************************************************/
int my_strcmp(char *str1, char *str2)
{while (*str1 != '\0' && *str2 != '\0')  // 同时遍历两个字符串{if (*str1 != *str2)  // 如果字符不相同,返回1{return 1;}str1++;str2++;}// 如果两个字符串长度不同,直接返回1if (*str1 != *str2){return 1;}// 如果完全遍历过后两个字符串都相同,返回0return 0;
}

这是库函数的写法:

int my_strcmp( char *str1, char *str2) {
    while (*str1 != '\0' && *str2 != '\0') {
        if (*str1 != *str2) {
            return *str1 - *str2;  // 返回字符差值
        }
        str1++;
        str2++;
    }
    
    // 如果字符串都已结束,则比较长度
    return *str1 - *str2;
}

一些小题目练练手

1.编写程序,将用户输入的字符串中的所有的字符a用*代替,然后输出。

分析:

通过循环结构遍历每个字符并且判断是否为子符a,

如果是字符a,用*字符替换此元素

循环的条件  用户输入的字符串不是'\0'

2.输入一串字符,把其中的大写字母变成小写字母并输出

分析:

用户输入一个字符串,

通过循环结构遍历每个字符,

判断如果某个字符是大写的就把此元素替换为对应的字符小写

循环条件是  '\0'

3.写一函数判断一字符串是否为回文,是返回1,不是返回0,

"123321"              

"12321"

"asdffdsa"  

"asdfdsa"

分析:

用第一个 与最后一个比较 ,以此类推, 如果出现不相等的就不是回文

循环结构正常结束,就是回文。


1.

#include <stdio.h>int main()
{char a[100];int i = 0;printf("请输入字符串:");scanf("%s",a);while(a[i] != '\0'){if(a[i] == 'a'){a[i] = '*';}i++;}printf("已经将所以'a'替换成了‘*’\n替换后的字符串为:%s",a);return 0;
}

2.

#include <stdio.h>int main()
{char a[100];int i = 0;printf("请输入字符串:");scanf("%s",a);while(a[i] != '\0'){if(a[i] >= 'A'&& a[i] <='Z'){a[i] += 32;}i++;}printf("已经将所以大写字母替换成对应的小写字母\n替换后的字符串为:%s",a);return 0;
}

3.

#include <stdio.h>
#include <string.h>int pal(char *str);int main()
{char a[100];int judge;printf("请输入字符串:");scanf("%s",a);judge = pal(a);if(judge == 1){printf("是回文");}else if(judge == 0){printf("不是回文");}return 0;
}int pal(char *str){int len = strlen(str);for(int i = 0 ;i < len/2;i++){if(*(str+i) != *(str+len-1-i)){return 0;}}return 1;}

相关文章:

C_字符串的一些函数

1.字符串输入函数 scanf("%s",数组名)&#xff1b; gets(数组名)&#xff1b; 区别&#xff1a; scanf(“%s”,数组名); 把空格识别为输入结束 #include <stdio.h>int main() {char a[10];printf("输入&#xff1a;");scanf("%s",a)…...

使用Native AOT发布C# dll 提供给C++调用

Native AOT&#xff0c;即提前本地编译&#xff08;Ahead-Of-Time Compilation&#xff09;&#xff0c;是一种将托管代码&#xff08;如 C#&#xff09;编译为本机可执行文件的技术&#xff0c;无需在运行时进行任何代码生成。 &#xff08;Native AOT 优缺点截图摘自张善友博…...

Git 提交代码日志信息

前言 在项目中经常用到git提交代码&#xff0c;每次提交时需要添加日志信息&#xff0c;那么一套规范的日志信息会让整个git仓库看起来赏心悦目&#xff01; 以下是Git 提交代码日志信息的建议&#xff1a; 一、格式规范 标题&#xff08;Subject&#xff09; 标题是日志信息中…...

Request method ‘POST‘ not supported(500)

前端路径检查 查看前端的请求路径地址、请求类型、方法名是否正确&#xff0c;结果没问题 后端服务检查 查看后端的传参uri、传参类型、方法名&#xff0c;结果没问题 nacos服务名检查 检查注册的服务是否对应&#xff08;我这里是后端的服务名是‘ydlh-gatway’,服务列表走…...

终端环境下关闭显示器

终端环境下关闭显示器 使用vbetool vbetool 使用 lrmi 来运行视频 BIOS 中的代码。目前&#xff0c;它能够更改 DPMS 状态、保存/恢复视频卡状态并尝试从头开始初始化视频卡。 vbetool dpms off...

常见排序算法总结 (三) - 归并排序与归并分治

归并排序 算法思想 将数组元素不断地拆分&#xff0c;直到每一组中只包含一个元素&#xff0c;单个元素天然有序。之后用归并的方式收集跨组的元素&#xff0c;最终形成整个区间上有序的序列。 稳定性分析 归并排序是稳定的&#xff0c;拆分数组时会自然地将元素分成有先后…...

【后端开发】Go语言编程实践,Goroutines和Channels,基于共享变量的并发,反射与底层编程

【后端开发】Go语言编程实践&#xff0c;Goroutines和Channels&#xff0c;基于共享变量的并发&#xff0c;反射与底层编程 【后端开发】Go语言高级编程&#xff0c;CGO、Go汇编语言、RPC实现、Web框架实现、分布式系统 文章目录 1、并发基础, Goroutines和Channels2、基于共享…...

PyTorch 2.5.1: Bugs修复版发布

一&#xff0c;前言 在深度学习框架的不断迭代中&#xff0c;PyTorch 社区始终致力于提供更稳定、更高效的工具。最近&#xff0c;PyTorch 2.5.1 版本正式发布&#xff0c;这个版本主要针对 2.5.0 中发现的问题进行了修复&#xff0c;以提升用户体验。 二&#xff0c;PyTorch 2…...

【Android】组件化嘻嘻嘻gradle耶耶耶

文章目录 Gradle基础总结&#xff1a;gradle-wrapper项目根目录下的 build.gradlesetting.gradle模块中的 build.gradlelocal.properties 和 gradle.properties 组件化&#xff1a;项目下新建一个Gradle文件定义一个ext扩展区域config.gradle全局基础配置&#xff08;使用在项目…...

vulnhub靶场【哈利波特】三部曲之Aragog

前言 使用virtual box虚拟机 靶机&#xff1a;Aragog : 192.168.1.101 攻击&#xff1a;kali : 192.168.1.16 主机发现 使用arp-scan -l扫描&#xff0c;在同一虚拟网卡下 信息收集 使用nmap扫描 发现22端口SSH服务&#xff0c;openssh 80端口HTTP服务&#xff0c;Apach…...

HarmonyOS开发中,如何高效定位并分析内存泄露相关问题

HarmonyOS开发中&#xff0c;如何高效定位并分析内存泄露相关问题 (1)Allocation的应用调试方式Memory泳道Native Allocation泳道 (2)Snapshot(3)ASan的应用使用约束配置参数使能ASan方式一方式二 启用ASanASan检测异常码 (4)HWASan的应用功能介绍约束条件使能HWASan方式一方式…...

java调用ai模型:使用国产通义千问完成基于知识库的问答

整体介绍&#xff1a; 基于RAG&#xff08;Retrieval-Augmented Generation&#xff09;技术&#xff0c;可以实现一个高效的Java智能问答客服机器人。核心思路是将预先准备的问答QA文档&#xff08;例如Word格式文件&#xff09;导入系统&#xff0c;通过数据清洗、向量化处理…...

2023年第十四届蓝桥杯Scratch国赛真题—推箱子

推箱子 程序演示及其源码解析&#xff0c;可前往&#xff1a; https://www.hixinao.com/scratch/creation/show-188.html 若需在线编程&#xff0c;在线测评模考&#xff0c;助力赛事可自行前往题库中心&#xff0c;按需查找&#xff1a; https://www.hixinao.com/ 题库涵盖…...

银河麒麟V10-SP1设置redis开机自启

前言&#xff1a; redis安装请看&#xff1a;银河麒麟V10-SP1离线安装redis5.0.1_银河麒麟v10 redis5.0-CSDN博客 一、编辑自启文件 vim /etc/systemd/system/redis.service [Unit] DescriptionRedis In-Memory Data Store Afternetwork.target [Service] Typeforking ExecS…...

释放超凡性能,打造鸿蒙原生游戏卓越体验

11月26日在华为Mate品牌盛典上&#xff0c;全新Mate70系列及多款全场景新品正式亮相。在游戏领域&#xff0c;HarmonyOS NEXT加持下游戏的性能得到充分释放。HarmonyOS SDK为开发者提供了软硬协同的系统级图形加速解决方案——Graphics Accelerate Kit&#xff08;图形加速服务…...

Node.js 实战: 爬取百度新闻并序列化 - 完整教程

很多时候我们需要爬取一些公开的网页内容来做一些数据分析和统计。而多数时候&#xff0c;大家会用到python &#xff0c;因为实现起来很方便。但是其实Node.js 用来爬取网络内容&#xff0c;也是非常强大的。 今天我向大家介绍一下我自己写的一个百度新闻的爬虫&#xff0c;可…...

106.【C语言】数据结构之二叉树的三种递归遍历方式

目录 1.知识回顾 2.分析二叉树的三种遍历方式 1.总览 2.前序遍历 3.中序遍历 4.后序遍历 5.层序遍历 3.代码实现 1.准备工作 2.前序遍历函数PreOrder 测试结果 3.中序遍历函数InOrder 测试结果 4.后序遍历函数PostOrder 测试结果 4.底层分析 1.知识回顾 在99.…...

qt QToolButton详解

1、概述 QToolButton是Qt框架中的一个控件&#xff0c;它继承自QAbstractButton。QToolButton通常用于工具栏&#xff08;QToolBar&#xff09;中&#xff0c;提供了一种快速访问命令或选项的方式。与普通的QPushButton按钮相比&#xff0c;QToolButton通常只显示一个图标而不…...

2024年大热,Access平替升级方案,也适合Excel用户

欢迎各位看官&#xff0c;您来了&#xff0c;就对了&#xff01; 您多半是Access忠实粉丝&#xff0c;至少是excel用户&#xff0c;亦或是WPS用户吧。那就对了&#xff0c;今天的分享肯定对您有用。 本文1100字&#xff0c;阅读时长2分50秒&#xff01; 现实总是不尽人意&am…...

探索Scala的模式匹配:身份证识别与等级判定!!! #Scala # scala #匹配模式

在Scala编程语言中&#xff0c;模式匹配是一个强大且表达力丰富的特性&#xff0c;它允许我们以声明式的方式处理多种情况。今天&#xff0c;我们将通过两个有趣的例子来展示Scala模式匹配的魅力&#xff1a;身份证号识别和等级判定。 1. 身份证号识别&#xff1a;定位你的家乡…...

python数据分析之爬虫基础:爬虫介绍以及urllib详解

前言 在数据分析中&#xff0c;爬虫有着很大作用&#xff0c;可以自动爬取网页中提取的大量的数据&#xff0c;比如从电商网站手机商品信息&#xff0c;为市场分析提供数据基础。也可以补充数据集、检测动态变化等一系列作用。可以说在数据分析中有着相当大的作用&#xff01;…...

【星海随笔】syslinux

Ubuntu相关资料 https://www.pugetsystems.com/labs/hpc/ubuntu-22-04-server-autoinstall-iso/#Step_2_Unpack_files_and_partition_images_from_the_Ubuntu_2204_live_server_ISO https://launchpad.net/ubuntu/source/squashfs-tools/1:4.6.1-1build1 sudo tar -xf my_compu…...

力扣C语言刷题记录 (二)移除元素

给你一个数组 nums 和一个值 val&#xff0c;你需要 原地 移除所有数值等于 val 的元素。元素的顺序可能发生改变。然后返回 nums 中与 val 不同的元素的数量。 假设 nums 中不等于 val 的元素数量为 k&#xff0c;要通过此题&#xff0c;您需要执行以下操作&#xff1a; 更改…...

【Vue3】【Naive UI】<NAutoComplete>标签

【Vue3】【Naive UI】标签 <NAutoComplete> 是 Naive UI 库中的一个组件&#xff0c;用于实现自动完成或联想输入功能。 它允许用户在输入时看到与当前输入匹配的建议列表&#xff0c;从而帮助用户更快地填写表单字段。 这个组件通常用于搜索框、地址输入等场景&#xff…...

【Halcon】使用均值滤波出现假边怎么办?

在图像处理过程中,均值滤波是一种常见的平滑技术,用于减少图像中的噪声。然而,当应用于具有显著边缘或对比度变化的图像时,均值滤波可能会导致“假边”现象,即原本不存在的边缘在滤波后变得明显。以下是如何在Halcon中处理这一问题,并提供一个完整的示例代码。 示例背景…...

Flask+Minio实现断点续传技术教程

什么是MinIO MinIO是一个高性能的分布式对象存储服务&#xff0c;与Amazon S3 API兼容。它允许用户存储和检索任意规模的数据&#xff0c;非常适合于使用S3 API的应用程序。MinIO支持多租户存储&#xff0c;提供高可用性、高扩展性、强一致性和数据持久性。它还可以作为软件定义…...

JAVA设计模式,动态代理模式

动态代理&#xff08;Dynamic Proxy&#xff09;是Java中一种非常有用的设计模式。它允许在运行时创建一个实现了一组给定接口的新类。这种模式主要用于当需要为某个对象提供一个代理以控制对该对象的访问时。通过这种方式&#xff0c;可以添加额外的功能&#xff0c;如事务管理…...

HTML 快速上手

目录 一. HTML概念 二. HTML标签 1. 标题标签 2. 段落标签 3. 换行标签 4. 图片标签 5. 超链接标签 6. 表格标签 7. 表单标签 7.1 form 标签 7.2 input 标签 (1) 文本框 (2) 单选框 (3) 密码框 (4) 复选框 (5) 普通按钮 (6) 提交按钮 8. select标签 9. 无语义…...

【计算机视觉算法与应用】模板匹配、图像配准

目录 1. 基于灰度值的模板匹配 2. 基于相关性的模板匹配 3. 基于形状的模板匹配 4. 基于组件的模板识别 5. 基于形变的模板匹配 6. 基于描述符的模板匹配 7. 基于点的模板匹配 性能比较 模板匹配的算法实现需要结合具体需求和应用场景来选择方法。以下是基于 OpenCV 的…...

【Linux】设计文件系统(C实现)

要求&#xff1a; (1)可以实现下列几条命令 dir 列文件目录 create 创建文件 delete 删除文件 read 读文件 write 写文件 (2)列目录时要列出文件名、存取权限&#xff08;八进制&#xff09;、文件长度、时间&#xff08;创建时间&#xff0c;修改时间以及…...