字符输入和输出函数

#include <stdio.h>
int main()
{int c;c = getchar();putchar(c);putchar('\n');return 0;
}

字符串与字符数组的关系

字符串经常以常量的形式出现

字符串常量的例子:"a + b - c"

字符串以常以字符数组内容的形式出现

字符串常量与一般字符数组中的字符数组不同,

字符串常量在程序内部保存在字符数组中,字符串常量位于特殊的存储区域

字符数组初始化的两种方式

char   str[ ] = { 'H', 'e' , 'l' , 'l' , 'o'};

(5个元素,无字符结束符)

(不是一个完整的字符串)

char   str[ ] = "Hello";

(6个元素, 自动加上最后一个字符串结束符 '\0')

(是一个完整的字符串)

字符串存储形式

例:"a + b - c"

长度:5

包含字符个数:6

最后一个字符:’\0'

字符串输出函数

#include <stdio.h>
#include <string.h>
int main()
{char a[] = "hello";puts(a);puts("world");  /*注意该函数自动换行功能*/return 0;
}

字符串输入问题

有问题代码,scanf()遇到空格就自动终止输入

scanf()函数详解

函数原型:(int)scanf()

scanf("%d",&x)有三种返回值:

  1. 返回1表示成功读入一项数据
  2. 返回0表示读入数据失败
  3. 返回EOF表示遇到了文件结束(可以用Ctrl-Z或Ctrl-D送入文件结束信息EOF)

从标准输入上读入以空格、tab键或换行符分隔的字符序列

不包含用于分隔各个输入字段的空白符

#include <stdio.h>
int main()
{char s1[13], s2[13];scanf("%s\n%s", s1, s2);printf("%s\n%s\n", s1, s2);s2[2] = '9';     /*注意9上必须加''(单引号)*/printf("%s\n", s2); return 0;
}

正确操作

char *gets(char s[ ]);

读入字符序列,直至换行符或输入数据的结尾

将字符序列保存在一个字符数组中,在输入数据末尾加上字符串结束符 ' \0 '

为防止黑客攻击(缓冲区溢出攻击)用fgets( )代替gets( )

char * fgets ( char *s, int n, FILE *fp);

gets( )与fgets( ) 的区别

  1. 在输入数据末尾加上字符串结束符 ' \0 '(预留最后一个空格)
  2. fgets( )最多只读入 n - 1 个字符,以确保任何输入数据都不会造成缓冲区溢出
  3. 如果缓冲区s足够大,并且输入数据中包含换行符,则该换行符会被保存在缓冲区s中
  4. 在使用fgets( )时必须指明数据的来源,例如使用标识符stdin说明数据来自标准输入

gets( )函数例子

输入:187 9927 2683

输出:189 9927 2683

#include <stdio.h>
#include <string.h>
int main()
{char s1[13];gets(s1);s1[2] = '9';     /*注意9上必须加''(单引号)*/puts(s1); return 0;
}

fgets( )函数例子

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize];fgets(s1, Maxsize, stdin);s1[2] = '9';     /*注意9上必须加''(单引号)*/puts(s1); return 0;
}

练习

输入:

18799272683

15631468722

输出:

18999272683

15631468722

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize], s2[Maxsize];gets(s1);gets(s2);s1[2] = '9';puts(s1);puts(s2);return 0;
}

输入:

18799272683

15631468722

输出:

1899927268315631468722

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize], s2[Maxsize];gets(s1);gets(s2);s1[2] = '9';printf("%s", s1);printf("%s", s2);return 0;
}

输入:.

187 9927 2683

156 3146 8722

输出:

189 9927 2683

156 3146 87222

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize], s2[Maxsize];fgets(s1, Maxsize, stdin);fgets(s2, Maxsize, stdin);s1[2] = '9';     /*注意9上必须加''(单引号)*/puts(s1);puts(s2); return 0;
}

输入:

187 9927 2683

156 3146 8722

输出:

189 9927 2683

156 3146 8722

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize], s2[Maxsize];fgets(s1, Maxsize, stdin);fgets(s2, Maxsize, stdin);s1[2] = '9';     /*注意9上必须加''(单引号)*/printf("%s", s1);printf("%s", s2); return 0;
}

输入n行字符串

输入:

2

187 9927 2683

181 3210 6429

输出:

187 9927 2683

181 3210 6429

#include <stdio.h>
#include <string.h>
int main()
{int N;int i;scanf("%d\n", &N); /*不要忘记'\n'*/char s[N][90];for(i = 0; i < N; i++)gets(s[i]);for(i = 0; i < N; i++)puts(s[i]);return 0;
}

等价代码 

#include <stdio.h>
#include <string.h>
int main()
{int N;int i;scanf("%d\n", &N); /*不要忘记'\n'*/char s[N][90];for(i = 0; i < N; i++)fgets(s[i], 90, stdin);for(i = 0; i < N; i++)printf("%s", s[i]);return 0;
}

字符串逆置函数

#include <stdio.h>
#include <string.h>
#define Maxsize 100
void rev(char s[])
{int head = 0, rear = 0;char t;while(s[rear] != '\0')  /*rear不能从-1算起,因为无s[-1]此项!*/ rear++;for(rear--; head < rear; head++, rear--){t = s[head];s[head] = s[rear];s[rear] = t;}
}
int main()
{char s[Maxsize] = "Peking University";puts(s);rev(s);puts(s);return 0;
}

更具有通用性的改进版

#include <stdio.h>
#include <string.h>
#define Maxsize 100
void rev(char s[])
{int head = 0, rear = 0;char t;while(s[rear] != '\0')  /*rear不能从-1算起,因为无s[-1]此项!*/ rear++;for(rear--; head < rear; head++, rear--){t = s[head];s[head] = s[rear];s[rear] = t;}
}
int main()
{char s[Maxsize];gets(s);rev(s);puts(s);return 0;
}

字符串复制函数

char *strcpy (char dest[ ], char src[ ] );

char *strncpy(char dest[ ], char src[ ], int n);

dest---destination,  src---source

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize];char s[2][Maxsize];gets(s1);strcpy(s[0], s1);s1[2] = '9';strcpy(s[1], s1);int i;for(i = 0; i < 2; i++)printf("%s\n", s[i]);return 0;} 

注意:函数strncpy( )有可能因n太小没有 '\0', 需要时需添加

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char s1[Maxsize];char s[2][Maxsize];gets(s1);strncpy(s[0], s1, 5);s1[2] = '9';strcpy(s[1], s1);int i;for(i = 0; i < 2; i++)printf("%s\n", s[i]);char s2[Maxsize];strcpy(s2, s[0]);puts(s2);return 0;} 

输出:That is nobook

#include <stdio.h>
#include <string.h>
#define Maxsize 100
int main()
{char d[Maxsize] = "This is a book";char s[Maxsize] = "That is not his pen";strncpy(d, s, 10);puts(d);
}

函数的实现 strcpy( )

char *strcpy(char dest[], char src[])
{int i = 0;while(dest[i] = src[i]) ++i; /*(dest[i] = src[i]的值是当前正在复制的字符*/
}

函数的实现strncpy( )

#include <stdio.h>
#include <string.h>
#define Maxsize 100
char *stringncopy(char dest[], char src[], int n)
{int i;while(src[i] != '\0') i++;int k;if(n <= i){for(k = 0; k < n ;k++)dest[k] = src[k];}else{for(k = 0; k <= i; k++)dest[k] = src[k];  }return dest;
}
int main()
{char s1[Maxsize] = "This is a book";char s2[Maxsize] = "That is not his pen";stringncopy(s1, s2, 10);puts(s1);char s3[Maxsize] = "This is a book";stringncopy(s2, s3, 10);puts(s2);return 0;
}

输出:That is not his p

#include <stdio.h>
#include <string.h>
#define Maxsize 100
char *stringncopy(char dest[], char src[], int n)
{int i = 0;while(src[i] != '\0') i++;int k;if(n <= i){for(k = 0; k < n ;k++)dest[k] = src[k];}else{for(k = 0; k <= i; k++)dest[k] = src[k];            }return dest;
}
int main()
{char s1[Maxsize] = "This is a book";char s2[Maxsize] = "That is not his pen";stringncopy(s1, s2, 17);puts(s1);return 0;
}

更改一个字符数组的错误做法(不同于数字数组)

char s1[Maxsize] = "This is a book";
char s1[Maxsize] = "File av not cv";

正确做法

char s1[Maxsize] = "This is a book";
strcpy(s1, "File av not cv");

字符串追加函数

函数原型

char *stract(char dest[ ], char src[ ]);

char *strnact(char dest[ ], char src[ ], int n);

字符串前缀删除函数

#include <stdio.h>
#include <string.h>
#define Maxsize 40
void delPrefix(int dnum, char a[])
{int i = 0;while((a[i] = a[i+dnum]) != '\0')i++;
}
int main()
{char b[13] = "Good morning";delPrefix(5, b);puts(b);return 0;
}

字符串比较函数

int strcmp(char s1[ ], char s2[ ]);

#include <stdio.h>
#include <string.h>
int main()
{char a[] = "hello world";char b[] = "hello World";char c[] = "world hello";printf("a-b:%d\t", strcmp(a,b));printf("a-b:%d\t", strncmp(a, b, 5));printf("a-c:%d\n",strcmp(a,c));return 0;} 

字符串检查函数

#include <stdio.h>
#include <string.h>
int main()
{char a[] = "Hello world";printf("strlen(a):%d\t", strlen(a));return 0;} 

字符及字符串(数字串)输入输出字符串处理函数相关推荐

  1. 找出连续最长数字串python_字符串中找出连续最长的数字字符串的实例代码

    //1. 写一个函数,它的原形是int continumax(char *outputstr,char *intputstr) //功能: //在字符串中找出连续最长的数字串,并把这个串的长度返回, ...

  2. 在字符串中找出连续最长的数字串

    微软面试题之一,难度系数低. 题目描述如下: 写一个函数,它的原形是int continumax(char *outputstr,char *intputstr)  功能:  在字符串中找出连续最长的 ...

  3. Java-正则表达式:匹配特定字符开头,数字结尾的任一字符串

    1.需求:通过正则表达式去匹配特定字符开头,数字结尾的字符串 我这里去匹配字符"+,-,@,="开头,数字结尾的字符串 2.代码 public class Test_Leo {pu ...

  4. 《好未来编程题》字符串中找出连续最长的数字串

    题目:读入一个字符串str,输出字符串str中的连续最长的数字串 输入描述: 个测试输入包含1个测试用例,一个字符串str,长度不超过255. 输出描述: 在一行内输出str中里连续最长的数字串. 示 ...

  5. 软件的基本是要处理好”算法“及其基础(一)流-字-字符(包括某个数字、字母、符号和某个汉字等)-字符串-字节动态数组-字节-整数之间的转化关系和算法

    目录 软件的基本是要处理好"算法"及其基础(一): 流->计算机字->字符(包括某个数字.字母.符号和某个汉字等)->字符串->字节动态数组->字节- ...

  6. 编程小练习:最大公约数,字符串反序输出,全排列,不用加减法求和,字符串内容反序,字符串中最长数字串,数组是否递增,数组反转,链表反转,翻转单词顺序

    最大公约数 --- 递归.非递归 #include <stdio.h>int gcd(int a, int b); int gcd_recursive(int a, int b);int ...

  7. 编写一函数,由实参传来一个字符串,统计此字符串中字母、数字、空格和其它字符的个数,在主函数中输入字符串以及输出上述的结果。

    知识点:函数的调用和字符数组的运用. 字符数组是指用来存放字符数据的数组.其定义的一般形式为: char 数组名[数据长度] .字符数组用于存放字符或字符串,字符数组中的一个元素存放一个字符,它在内存 ...

  8. c语言字符型输入格式化,c语言之字符串和格式化输入输出

    字符串和格式化输入输出 #include #include #define DENSITY 62.4 int main(void) { float weight, volume; int size, ...

  9. 字符和字节详解、Java中字节串和字符串相互转换

    字符.字节和编码 1. 程序中的字符与字节 字节是规定存储大小的存储单位,规定为8位一字节(8bit = 1 byte). 字符是人类的描述符号.存储在计算机时,不同的编码格式会有不同的字节组合,一般 ...

最新文章

  1. web3.js(二)根据私钥推出地址查询以太数量
  2. java try、catch、finally及finally执行顺序详解
  3. (十一)Json文件配置
  4. mysql 数据库 额外_mysql – 拥有“额外”数据库查询有多糟糕?
  5. 数据分析工具篇pyspark应用详解——Pyspark实现PCA主成分
  6. 网络恶意营销账号猖獗,国家网信办出手了
  7. 特斯拉联合苹果发难 要对小鹏汽车“窃密”员工动手了...
  8. CSS工具之CSS重置(CSS Reset)
  9. 【java学习之路】(java SE篇)(练习)3个经典小问题
  10. 2.windows-and-mac在控制台创建ASP.NET-Core应用程序
  11. phpstudy不安装mysql_MySQL_mysql安装不上怎么办 mysql安装失败原因和解决方法,mysql数据库安装不了了!mysql最 - phpStudy...
  12. 网易云课堂 html5,网易云课堂 HTML5 播放器样式调整
  13. MarkdownNote
  14. 基于神经网络的文字识别,神经网络如何识别图像
  15. elementui去掉表格所有边框
  16. 如何实现ps的批量处理图片
  17. 我理解的云桌面(或桌面云)
  18. linux ubuntu18.1安装教程,Ubuntu 18.04上Qmmp安装教程
  19. AtCoder题解——Beginner Contest 170——F - Pond Skater
  20. java期末_Java期末总结

热门文章

  1. mysql group_concat去重_mysql GROUP_CONCAT 函数 将相同的键的多个单元格合并到一个单元格...
  2. Elasticsearch 8.X 集群无响应,怎么办?
  3. 孩子发烧,别急着降温
  4. 淘宝天猫、1688、京东、拼多多原数据api接口
  5. BUUWeb刷题记录
  6. python打开pdf文档
  7. windows重装系统步骤及相关知识①
  8. java 开发安卓im_Android端IM应用中的@人功能实现:仿微博、QQ、微信,零入侵、高可扩展...
  9. 智慧边缘计算安全综述
  10. 网络安全笔记-Web架构