• Coursera课程笔记----计算导论与C语言基础----Week 11


    C程序中的字符串(Week 11)

    字符数组

    • 所有的字符串,都是以结尾

    • 只能在数组定义并初始化的时候:char c[6] = "China";

    • 不能用赋值语句将一个字符串常量字符数组直接赋给另一个字符数组

    • 可以利用二维字符数组存储多个字符串

    字符/字符数组/字符串的输入与输出

    输入的过程

    • 输入缓冲区

      输入的时候会有一个指针标定我们读取到哪里(缓冲区指针)

    • 用cin输入数据

      连续输入的情况 while(cin>>i)

    一个字符的输入和输出

    • 方法一:直接用cin输入字符(cin会把空格和回车当作数据之间的间隔符号,不认为其本身是数据
    • 方法二:从cin.get()函数输入字符
      • 用于读入一个字符
      • 可无参数or一个参数(char)
      • 该方法不会忽略空格和回车,而是当作普通字符处理
    • 方法三:用cin.get(char)输入字符
      • 读取一个值赋给char
      • 该方法不会忽略空格和回车,而是当作普通字符处理
    • 方法四:用getchar()输入字符
      • 该方法不会跳过任何字符,包括结束符。

    一串字符的输出

    • 用cout输出字符数组:在遇到后中止

    一串字符的输入

    • 方法一:直接用cin输入字符串(cin会把空格和回车当作字符串之间的间隔符号
    • 方法二:用cin.get()函数输入
      • 有3个参数的get函数 cin.get(ch,10,' '); //读取10-1个字符(包含空格)赋给ch,如果在读取10-1个字符之前碰到了设定的中止字符,则结束。读取成功返回,失败返回
    • 方法三:用cin.getline()函数输入(参数同上)
      • getline和get的区别
        • getline遇到终止标志字符时结束,缓冲区指针移到终止标志字符之后
        • get遇到终止字符是停止读取,指针不移动
        • cin.getline更常用,因为中止字符通常都是换行符,因此getline比较方便
    #include<iostream>
    using namespace std;
    int main()
    {
      char a[10][10];
      int n = 0;
      cin >> n;
      cin.get(); //添加一条语句,“拿走”上一句话指针停止在的换行符
      for(int i = 0; i < n; i++)
        cin.getline(a[i],10);
      for(int i = 0; i < n; i++)
        cout<<a[i]<<endl;
      return 0;
    }
    

    字符串应用

    例1 字符串加密

    • 问题

      • 输入一个字符串,把每个字符变成它的后续字符,然后输出变换后的字符,要求能够接受连续输入。
    • 思路

      • 读入字符串(想一下以什么方式输入?)
      • 从字符头到尾循环:
        • 是‘Z'/‘z’则直接赋值’A'/‘a’,跳过以下步骤
        • 空格不做处理,跳过以下步骤
        • 其他字符++
      • 输出新字符串
      #include<iostream>
      using namespace std;
      int main()
      {
        char str[200];
        while(cin.getline(str,200))
        {
          for(int i = 0; str[i] !='/0';i++)
          {
            if(str[i] == 'Z')
            {
              str[i] = 'A';
              continue;
            }
            if(str[i] == 'z')
            {
      				str[i] = 'a';
              continue;
            }
            if(str[i] == ' ')
              continue;
            str[i]++;
          }
          cout<<str<<endl;
        }
        return 0;
      }
      

    例2 字符串链接

    • 问题

      • 输入两个字符串,将其中较短的串接到较长的串的后面
    • 要求

      • 不使用系统函数strcat
      • 每个输入的串的长度不超过20
    • 思路

      • 定义: char str1[40],str2[40]; cin.getline(str1,20);cin.getline(str2,20);

      • 计算长度: for(len1 = 0; str1[len1]!='';len1++);for(len2 = 0; str2[len2]!='';len2++);

      • 拼接:第一个串的下标指向最后一个元素之后,第二个串的下标指向第一个元素

        for(len2 = 0; str1[len2]!='';len2++);

        ​ str1[len1++] = str2[len2];

        ​ str1[len1]='/0'; //加上就变成了一个字符串

    #include<iostream>
    using namespace std;
    int main()
    {
      int len1,len2;char str1[40],str2[40];
      cin.getline(str1,20);cin.getline(str2,20);
      for(len1=0;str1[len1]!='';len1++);
      for(len2=0;str2[len2]!='';len2++);
      if(len1 >= len2)
      {
        for(len2 = 0; str2[len2]!='';len2++)
          str1[len1++] = str2[len2];
        str1[len1] = '';
      }
      else
      {
    		for(len1 = 0; str2[len1]!='';len1++)
          str2[len2++] = str1[len1];
        str2[len2] = '';
      }
      cout<<str1<<endl;
      cout<<str2<<endl;
      return 0;
    }
    

    例3 统计单词数

    • 问题
      • 输入一个英文句子(不超过80个字母),统计其中有多少个单词,单词之间用空格分开
    #include<iostream>
    using namespace std;
    int main()
    {
      char str[80];
      int num = 0, flag = 0;
      cin.getline(str,80);
      for(int i = 0; str[i]!='';i++)
      {
        if(str[i] == ' ')
          flag = 0;
        else if(flag == 0)
        {
          flag = 1;
          num++;
        }
      }
      cout<<"字符串中有"<<num<<"个单词"<<endl;
      return 0;
    }
    
  • 相关阅读:
    没人比程序猿更讨厌软件
    随心所欲~我也做个集合遍历器吧(自己的foreach,委托的威力)
    EF架构~DefaultValue让我的UnitOfWork更可读
    EF架构~数据分批批量提交
    陷阱~EF中的Update与Insert共用一个数据上下文
    我心中的核心组件(可插拔的AOP)~第四回 异常拦截器
    zigbee学习:示例程序SampleApp中通讯流程
    【网络可靠版】Extjs4 Treegrid 使用实例
    C#实现微信公众号群发消息(解决一天只能发一次的限制)
    oracle12c(oracle12.1.0.1.0)安装指南--实测OEL5.9(RH5)
  • 原文地址:https://www.cnblogs.com/maimai-d/p/12813622.html
Copyright © 2020-2023  润新知