zoukankan      html  css  js  c++  java
  • 【C++】常用知识点

    1.按有效位输出是 setprecision,按小数位数输出也是setprecision,但到底是谁取决于fixed。
    cout << resetiosflags(ios::fixed) << setprecision(n) << float-point-number; 是按n位有效数输出
    cout << setiosflags(ios::fixed) << setprecision(n) << float-point-number; 是按n位小数输出

     

    2.C++分隔字符串函数

    char *strtok( char *strToken, const char *strDelimit);

     参数说明:strToken:   包含 token 的字符串, 即待分割串; strDelimit: token 的集合, strToken 会根据这里的每个字符进行分割

    返回值:返回指向第一段被截取出来的字符串的指针(根据 strDelimit 内的字符进行截取). 如果没有找到, 那么就返回 NULL.

     调用说明:
    (1). 第一次调用 strtok 时, 第一个参数是 strToken, 以后再调用时, 第一个参数必须是 NULL;

    (2). 调用 strtok 后, 原字符串会被修改;

    (3). strtok 不是一个线程安全的函数.

    //借助strtok实现split
     #include <string.h>
     #include <stdio.h>
     
     int main()
     {
             char s[] = "Golden Global      View,disk * desk";
             const char *d = " ,*";
             char *p;
             p = strtok(s,d);
             while(p)
             {
                     printf("%s\n",p);
                     p=strtok(NULL,d);
             }
     
             return 0;
     }
    

     3.C++字符串转化为数字的库函数(来自http://blog.csdn.net/tsinfeng/article/details/5844838

    1、atoi
    功 能:把一字符串转换为整数
    用 法:int atoi(const char *nptr);
    详细解释:atoi是英文array to integer 的缩写。atoi()会扫描参数nptr字符串,如果第一个字符不是数字也不是正负号返回零,否则开始做类型转换,之后检测到非数字或结束符 /0 时停止转换,返回整型数。 参 数:
      *nptr: 待转化的字符串。
    返回值:
     int: 转换后的整形数。
    备注:该函数的头文件是"stdlib.h"
     
    2、atol
    功 能:把一字符串转换为长整形
    用 法:long atol(const char *nptr);
    详细解释:atol()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('/0')才结束转换,并将结果返回。
    参 数:
      *nptr: 待转化的字符串。
    返回值:
     long: 转换后的长整形数。
    备注:该函数的头文件是"stdlib.h"
     
    3、atof
    功 能:把一个字符串转换为双精度浮点数
    用 法:double atof(const char *nptr);
    详细解释:atof()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时 ('/0')才结束转换,并将结果返回。参数nptr字符串可包含正负号、小数点或E(e)来表示指数部分,如123.456或123e-2。
    参 数:
      *nptr: 待转化的字符串。
    返回值:
     double: 转换后的双精度浮点数。
    备注:该函数的头文件是"stdlib.h"
     
    4、strtod
    功 能:将字符串转换为双精度浮点型值,并报告不能被转换的所有剩余数字
    用 法:double strtod(const char *nptr,char **endptr);
    详细解释:strtod()会扫描参数nptr字符串,跳过前面的空格字符,直到遇上数字或正负符号才开始做转换,到出现非数字或字符串结束时 ('/0')才结束转换,并将结果返回。若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。参数nptr 字符串可包含正负号、小数点或E(e)来表示指数部分。如123.456或123e-2。
    参 数:
      *nptr: 待转化的字符串。
      **endptr: 若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。
    返回值:
     double: 转换后的双精度浮点数。
    备注:该函数的头文件是"stdlib.h"
     
    5、strtol
    功 能:将字符串转换为长整形值,并报告不能被转换的所有剩余数字
    用 法:long int strtol(const char *nptr,char **endptr,int base);
    详细解释:这个函数会将参数nptr字符串根据参数base来转换成长整型数。参数base范围从2至36,或0。参数base代表采用的进制 方式,如base值为10则采用10进制,若base值为16则采用16进制等。当base值为0时则是采用10进制做转换,但遇到如’0x’前置字符则 会使用16进制做转换、遇到’0’前置字符而不是’0x’的时候会使用8进制做转换。一开始strtol()会扫描参数nptr字符串,跳过前面的空格字 符,直到遇上数字或正负符号才开始做转换,再遇到非数字或字符串结束时('/0')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到 不合条件而终止的nptr中的字符指针由endptr返回。
    参 数:
      *nptr: 待转化的字符串。
      **endptr: 若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。
      base:采用的进制方式
    返回值:
     long int: 转换后的长整形数。
    备注:该函数的头文件是"stdlib.h"
     
    6、strtoul
    功 能:将字符串转换为无符号长整形值,并报告不能被转换的所有剩余数字。
    用 法:unsigned long int strtoul(const char *nptr,char **endptr,int base);
    详 细解释:strtoul()会将参数nptr字符串根据参数base来转换成无符号的长整型数。参数base范围从2至36,或0。参数base代表采用 的进制方式,如base值为10则采用10进制,若base值为16则采用16进制数等。当base值为0时则是采用10进制做转换,但遇到如'0x'前 置字符则会使用16进制做转换。一开始strtoul()会扫描参数nptr字符串,跳过前面的空格字符串,直到遇上数字或正负符号才开始做转换,再遇到 非数字或字符串结束时('')结束转换,并将结果返回。若参数endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr 返回。
    参 数:
      *nptr: 待转化的字符串。
      **endptr: 若endptr不为NULL,则会将遇到不合条件而终止的nptr中的字符指针由endptr传回。
      base:采用的进制方式
    返回值:
     unsigned long int: 转换后的无符号长整形数。
    备注:该函数的头文件是"stdlib.h"

     

    4.C++ cin

    cin会把读入流之前的空格,之后的空白全部去掉,比如以下程序:

    View Code
     1 #include <iostream>
     2 using namespace std;
     3 
     4 int main()
     5 {
     6     int a,b;
     7     cin>>a>>b;
     8     cout << a+b << endl;
     9 
    10     system("pause");
    11     return 0;
    12 }

    输入1)数字,空格,数字,回车;2)空格,数字,空格,空格,回车;3)回车,数字,空格,数字,回车都可以得到正确结果。(换句话说,cin会自动忽略空格和回车)

     

  • 相关阅读:
    [LeetCode] 714. Best Time to Buy and Sell Stock with Transaction Fee
    [LeetCode] 309. Best Time to Buy and Sell Stock with Cooldown
    [LeetCode] 1291. Sequential Digits
    [LeetCode] 188. Best Time to Buy and Sell Stock IV
    [LeetCode] 123. Best Time to Buy and Sell Stock III
    [LeetCode] 581. Shortest Unsorted Continuous Subarray
    [LeetCode] 1041. Robot Bounded In Circle
    [LeetCode] 1110. Delete Nodes And Return Forest
    [LeetCode] 421. Maximum XOR of Two Numbers in an Array
    [LeetCode] 1109. Corporate Flight Bookings
  • 原文地址:https://www.cnblogs.com/lqminn/p/2675234.html
Copyright © 2011-2022 走看看