c++常犯错误,及解决办法

1.codeblocks中视图开关

code::blocks上方运行按钮被我点没了,怎么找回来_codeblocks上面的工具栏不见了-CSDN博客

2. codeblock中的调试

CodeBlocks调试简要教程_codeblocks怎么调试-CSDN博客

 调试步骤较繁琐,直接上原文,

3.codebs中的快捷键 

ctrl+shift+c   //注释

ctrl+shift+x  //取消注释

tab              //选中多行后退

shift+tab     //选中多行前进

4.c++中平方和开方

 C++的开方,平方,绝对值_c++ 平方-CSDN博客

5.c++中常见语法错误

1.double类型的值,需要用%.lf输出

2.for(int i=0;i<3;i++)  其中i为局部变量;

   int i=0;for(i,i<3,i++)才能在接下来的代码使用 i 

3.break语句只能用于循环语句和switch中,不能单独使用或用于其他语句中;

   break作用是使流程从循环体内跳出循环体,即提前结束循环;

  与之相对的是continue,continue语句提前结束本次循环,接着进行下一次是否执行循环的判定;

4. 但c++里面不存在这样的用法,while(cin>>n)是一个死循环(前提是一直输入数字),                         while((cin>>n)!=0)可以实现这个功能,如此便不再是死循环;

5.求阶乘时,尽量少定义int型变量,因为int型变量在14!是会超出int类型的取值范围,从而导致        结果错误;

6.闰年:2月份29天;判断如下 if((year%4==0&&year%100!=0)||year%400==0);能被4整除但不能      被     100整除,或者能被400整除;

7.codeblocks如何在debug时查看数组,在watch中手动输入需要查看的数组名,右键点击数组         名,选择count在合适的值(记得勾选上watch as array);

8.数组的初始赋值,eg:int num[100]={0}是可以将数组全赋值为0,但是int num[100]={1}时不能        够这么写的,最好就用个循环全部弄成1;

9.判断素数,i不用遍历到n,仅需要遍历到sqrt(n);

int func(int n)//判断是不是素数
{
    if(n==1) return 0;
    else
    {
        for(int i=2;i<=sqrt(n);i++)
        {
            if(n%i==0)
                return 0;
        }
        return 1;
    }
}

10.string类型需要双引号,char类型仅需要单引号;

11.把字符型变量赋值给int行变量会显示ASCII值 ,下图输出48;

#include <iostream>
#include <bits/stdc++.h>

using namespace std;
int main() {
    int i;
    i='0';
    cout<<i<<endl;
    return 0;
}

  在计算大精度的加法时,需要将数字用string类型存储,char i;   i-'0'转成数字;

12.cout<<'A'   输出是字符串A  ;cout<<'A'+10; 输出是65; 当要输出char类型时,应该使用强制类型转换cout<<char('A'+10); 输出即为K 

 13.在输入字符串时,cin会自动跳过空格,应该使用getline(cin,s) 这样就可以输入带空格的字符串;字符是可以比较大小的,eg:if(s[j]>='0'&&s[j]<='9')其中s时string类型;

 14.vector<char> v;   v.push_back(s[i]);其中s[i]可以时空格!!!!! 

15.c++里sort函数的使用C++中sort函数详解_c++ sort-CSDN博客 

sort(start,end,cmp)起始,结束,排序方法;sort(a,a+5); //数组从0开始,数组有多少个数就加多少

16.substr函数的使用 c++截取字符串_c++字符串的截取-CSDN博客

string s;   s.substr(i,n)//从i开始(数组下标)截取多少个字符;

17.pow(10,2)输出为99;因为pow时一个double类型,需要将int(pow(10,2)+0.1)这样就是100;

    pow(10,2)无限接近100,其数值约为99.9999999; 

18.codeblocks中如何使用字符串转数字stoi函数,stoi使用时必须参数字符串都是数字字符Code::Blocks——'stoi' was not declared in this scope_codeblocks error: 'stoi' was not declared in this -CSDN博客 stoi函数使用注意事项_stoi函数用不了-CSDN博客//stoi注意事项

to_string()函数将数字转成字符串;

19.求最大公约数,即求一个分数能不能约分

//辗转相除法
//15 12
//x y
//15%12=3
//12%3=0
int func(int x,int y)//求最大公约数4/10
{
    int z;
    while(x%y!=0)// 4/2
    {
        z=x%y;
        x=y;
        y=z;
    }
    return y;
}

 20.字符和数组可以相互使用

21.reverse 字符串颠倒函数 reverse(s.begin(),s.end());

22.char类型就直接比较ASCLL值。
字符串类型比较大小:
首先比较字符串中的第一个字符的ASCLL值。
如果第一个字符相同,则比较第二个字符仍相同,则比较第三…比较第N个字符,直至有不相同。
如果字符串长度不等,如(James和Jan)作比较,也取决于ASCLL值,两个字符串的前面两个字母都相同,则比较第三个,因为n的ASCLL值比m的大,所以Jan>James;
如果两个字符串比较到末尾还没出现不匹配,则比较短字符串被认为较小。                      
原文链接:https://blog.csdn.net/qq1539543073/article/details/114213997

23.集合操作

set<int> st;//集合的创建,可以自动排序,去重

 st.insert(x);//自动去重

 st.erase(x);//删除st集合中值为x的数

 for(set<int>::iterator i=st.begin();i!=st.end();i++)//遍历集合
                cout<<*i<<" ";

24.s.find() 也是输出数组下标的值

#include <iostream>
#include <string>

int main()
{
    std::string str = "Hello,world!";
    std::cout << str.find("w") << '\n'; // 输出6
    std::cout << str.find('H') << '\n'; // 输出0
    std::cout << str.find("abc") << '\n'; // 输出18446744073709551615(即string::npos)
}
//上面的代码会在控制台输出“7\n7\n18446744073709551615”。

25. swap(num[i][j],num[j][i]);可以交换两个值便于代码的简洁性

26.int num[n+1][n+1]={0};//不能这么操作,这样只能把第一个元素变成0

27.char('0'+i)    string s+=i;-----字符型加到字符串变成char类型

28.去除最高位

    int x=120;
    string s=to_string(x);
    s=s.substr(1);
    x=stoi(s);

29.itos的另一种实现

string i2s(int x)
{
    stringstream ss;
    ss<<x;
    string s;
    ss>>s;
    return s;
}

  • 32
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值