笔记收获*

目录

格式化字符串的使用

cout有效小数:

BMI:m/(h*h) 体重/身高的平方

sort排序:

int 与 char 类型转化:+-‘0’

最大公约数:

Vector容器的使用 

循环节——余数重复出现,商就重复出现(通过余数看循环)

getline()、cin.getline()


#include<cmath> 
abs(需要取绝对值的数字或者表达式)


#include <stdio.h>
printf("%02d",a);//用printf输出需要头文件stdio.h(好像不要也行)
输出格式为2位,不足的用0填充。

#include<iomanip>
cout<<setw(2)<<setfill(0)<<a;//将a以两位输出,不足的左侧以0补足;

#include<algorithm>
sort();//排序函数

sizeof()函数用来计算字符串的长度

#include <iomanip>  
//保留小数点后2位
cout << setiosflags(ios::fixed) << setprecision(2) << val << endl;
//保留2位有效数字
cout << setprecision(2) << val << endl;

#include<cstdio>
int a,b,c;
scanf("%d-%d-%d",&a,&b,&c); //年月日的输入
print("%d-%d-%d",a,b,c);  //年月日的输出

目录

格式化字符串的使用


格式化字符串的使用

1.调用格式为 printf("<格式化字符串>", <参量表>);
其中格式化字符串包括两部分内容: 一部分是正常字符, 这些字符将按原样输出; 另一部分是格式化规定字符, 以"%"开始, 后跟一个或几个规定字符, 用来确定输出内容格式。参量表是需要输出的一系列参数, 其个数必须与格式化字符串所说明的输出参数个数一样多, 各参数之间用","分开, 且顺序一一对应, 否则将会出现意想不到的错误。

2.格式化字符

%d 十进制有符号整数
%u 十进制无符号整数
%f 浮点数
%s 字符串
%c 单个字符
%p 指针的值
%e 指数形式的浮点数
%x, %X 无符号以十六进制表示的整数
%0 无符号以八进制表示的整数
%g 自动选择合适的表示法
说明:
(1). 可以在"%"和字母之间插进数字表示最大场宽。 例如: %3d 表示输出3位整型数, 不够3位右对齐。%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6, 小数点占一位, 不够9位右对齐。超过9位,按实际输出。%8s 表示输出8个字符的字符串, 不够8个字符右对齐。 如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。 但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出; 若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。另外, 若想在输出值前加一些0, 就应在场宽项前加个0。 例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度, 小数点前的数字代表最小宽度。 例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。
(2). 可以在"%"和字母之间加小写字母l, 表示输出的是长型数。例如: %ld 表示输出long整数, %lf 表示输出double浮点数。
(3). 可以控制输出左对齐或右对齐, 即在"%"和字母之间加入一个"-" 号可说明输出为左对齐, 否则为右对齐。例如: %-7d 表示输出7位整数左对齐,%-10s 表示输出10个字符左对齐。


3. 一些特殊规定字符
\n换行
\f清屏并换页
\r回车
\t Tab符
\xhh表示一个ASCII码用16进表示,
其中hh是1到2个16进制数

int a=1234;
    printf("a=%d\n",a);    //a=1234
    printf("a=%2d\n",a);   //a=1234    超过2位,按实际输出
    printf("a=%6d\n",a);   //a=  1234  不足6位,右对齐
    printf("a=%06d\n",a);  //a=001234  不足6位,前面补0
    printf("a=%-6d\n",a);  //a=1234    '-'左对齐
   

    int* i=&a;
    printf("i=%p\n",i);    //i=0012FF44  输出指针的值,即地址

    float m=8888.8888;     //float 单精度型浮点数 有效位数是6位或7位,根据不同的浮点数会有不同
    float m1=8888.8888f;    //在后面加上f或F,编译警告:truncation from'const double'to 'float'
                            //编译器默认浮点数为double
    float m2=8888.888f; 
    double n=8888.8888;
    double n1=8888888888.88888888;  //double 双精度型浮点数 有效位数是15位
    printf("m=%f\n m1=%f\n m2=%f\n n=%lf\n n1=%f\n",m,m1,m2,n,n1); // m=8888.888672
                                                                //  m1=8888.888672    
                                                                //  m2=8888.887695
                                                               // n=8888.888800
                                                               // n1=8888888888.888889
                                                               //%f的默认输出小数位数就是6位不管有没有l
    /*printf的%f说明符的确既可以输出float型又可以输出 double型。 根据"默认参数提升"规则(在printf这样的函数的
    可变参数列表中 ,不论作用域内有没有原型,都适用这一规则)float型会被提升为double型。因此printf()只会看到
    双精度数。严格地讲,%lf在printf下是未定义的,但是很多系统可能会接受它。要确保可移植性,就要坚持使用%f。*/

    printf("m4=%4.2f\n",m);   //宽度总共4位,小数两位,小数点一位,整数一位,这里整数超过宽度规定,按实际整数位输出
    printf("m5=%9.6f\n",m);   //浮点数小数部分不足6位,右对齐
    printf("m6=%9.2f\n",m);   //整数部分不足6位,右对齐;小数部分超过2位,四舍五入

    char c[20]="Hello,world!";
    printf("c=%s\n",c);   
    printf("c=%6.9s\n",c);  //c=Hello,wor  6.9s表示输出一个长度长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。

if(n/400==0 || (n/4==0 && n/100!=0))  //闰年的判断

获取类对象的成员方法getMethod()

getMethods()

invoke()

getModifiers();减少耦合度,中转,降低效率

final修饰class,class不可被继承

final char[] value;value不能变,只能指向定义时的数组空间

正则表达式

闰年:(1)能被4整除但不能被100整除;(2)能被400整除。

cout有效小数:

cout默认保留6位有效小数,cout.precision(4)保留4位有效小数。

BMI:m/(h*h) 体重/身高的平方

sort排序:

#include<algorithm>//头文件

int a[3];
1、sort(a,a+3);//从小到大排序,参数为指针(地址)
2、sort(a,a+3,greater<int>());//从大到小排序,sort排序左闭右开


3、bool cmp(int x,int y){
    return x > y;
  }
  sort(a, a + 3, cmp);//从大到小排序

int 与 char 类型转化:+-‘0’

int n=9;
char a;
int b;
a=n+'0';
b=a-'0';

最大公约数:

#include<algorithm>
int c =__gcd(a,b);

Vector容器的使用 

//头文件
#include<vector>
//对象的创建
vector<int> vec;//int可以改为char、string
vector<int> vec(10,1);//设置vector对象长度为10并每个元素初始化为1

vec.push_back(2);//尾部插入数字2
cout<<vec[0]<<endl;//使用下标访问元素,记住下标是从0开始的
vec.size();//获取长度

//遍历--通过下标读取
for(int i=0;i<vec.size();i++){
    cout<<vec[i]<<" ";
}

//遍历--通过迭代器
vector<int>::iterator it;
for(it=vec.begin();it!=vec.end();it++){
    cout<<*it<<" ";
}

//判断数字7是否在容器中,并获取其下标
if(find(vec.begin(),vec.end(),7)!=vec.end()){
    cout<<"数字7的下标是:"<<
distance( vec.begin() , find(vec.begin(),vec.end(),7) )<<endl;
//或者 find(vec.begin(),vec.end(),7) - vec.begin();
}

循环节——余数重复出现,商就重复出现(通过余数看循环)

//循环节--余数重复时陷入循环
int f(int n,int m){
    n = n % m;
    vector<int> remainder,quotient;
    for (;;){
        //将余数存入vector,判断下次余数是否重复
        remainder.push_back(n);
        n *= 10;
        //保存循环数字
        quotient.push_back(n / m);
        n = n % m;
        //判断余数是否重复
        if(find(remainder.begin(),remainder.end(),n)!=remainder.end()){
            cout <<"重复元素的下标:"<< find(remainder.begin(), remainder.end(), n)-remainder.begin() << endl;
            for (int i = 0; i < quotient.size();i++){
                cout << quotient[i] << " ";
            }
            cout << endl;
            //返回循环节的长度
            return remainder.end() - find(remainder.begin(), remainder.end(), n);
        }
    }
}

getline()、cin.getline()

#include<string>//需头文件string
string str1;
getline(cin,str1);//直接接收整个字符串
cout << str1 << endl;
//cin>>str1;是不能够接收空格的

//cin.getline(接收字符串的变量,接收字符个数,结束字符)
char str2[20];
cin.getline(str2,20);//需要指定接收字符串数组的长度(实际接收长度19,有'\0')
cout << str2<<endl;

两个都可以读取一整行字符串(含空格)

注意的问题
1、cin.getline()属于istream流,而getline()属于string流,是不一样的两个函数

2、当同时使用cin>>,getline()时,需要注意的是,在cin>>输入流完成之后,getline()之前,需要通过

str="\n";
getline(cin,str);

的方式将回车符作为输入流cin以清除缓存,如果不这样做的话,在控制台上就不会出现getline()的输入提示,而直接跳过,因为程序默认地将之前的变量作为输入流。

 Eclipse快捷键

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值