一、各进制赋值

1.十六进制赋值

  int i=0x12AD;

  int i=0X12AD;

  int i=0x12Ad;

  int i=0X12Ad;

  //以上都是十六进制,表示十进制173;

2.八进制赋值

  int num=017;

  //数字前面加0就是8进制,017表示十进制15,若写018则编译出错。(error C2041: 非法的数字“8”(用于基“8”))

二、int/char/string转换

1.char*/char[]转int:atoi()

  char* a="154";    int i=atoi(a);   //成功

  char a[]="154";    int i=atoi(a);   //成功

  char* a="abc";     int i=atoi(a);   //i=0,也没出错

2.int转char[](转char*老崩溃)

  int n=154;

  char p[10];

  itoa(n,p,16);  //非STL,vs里能用,一些在线oj不能用

  //十六是进制,可以自己指定。结果:p=“9a”;

3.char*/char[]转string

  char*/char[] p="dsdsdsd";

  string str=p;//直接赋值就行

4.string转char*

  string p="ewqewq";

  const char* o=p.c_str();//必须得是const

5.string/int互转

  通过char即可;

三、sscanf/sprintf(c语言)

  scanf:把键盘输入的数据给指定变量;

  printf:打印指定变量至屏幕;

  sscanf:把某const char*的数据给指定char*变量;

  sprintf:把数据输入到指定char*。

1.sscanf():int sscanf(const char *buffer, const char *format, [argument ]...);

  e.g.char buf[512] ;
    sscanf("123456 ", "%s", buf);
    printf("%s\n", buf);
    结果为:123456

  e.g.sscanf("123456 ", "%4s", buf);
    printf("%s\n", buf);
    结果为:1234

2.sprintf():int sprintf(char *buffer, const char *format, [argument] … );

  格式控制符的类型要和后面argument的类型一样。

  sprintf(s, "%d", 123);  //把整数123打印成一个字符串保存在s中,

  sprintf(s, "%8x", 4567);  //小写16进制,宽度占8个位置,右对齐

  sprintf(buf, "fdsafsdf");

  char a = 'a';    sprintf(buf, "The ASCII code of a is %d.", a);

四、位操作运算

  位操作只能用于整形数据,对实类型进行位操作会被编译器报错。

1.&(与操作)

  int i=100;(二进制1100100)

  则i&1=0;//只是最后一位和1进行与运算,所以可以判断奇偶性;

2.^(异或,两者不同则为1)

  void Swap(int &a, int &b)  
  {  
      if (a != b)  
      {  
          a ^= b;  
          b ^= a;  
          a ^= b;  
      }  
  }  //交换两个数不用第3个变量

3.移位

  e.g.int n=98;

n=n>>1;//n=49;

  <<各二进位全部左移若干位,高位丢弃,低位补0

  >>各二进位全部右移若干位,对无符号数,高位补0,有符号数,各编译器处理方法不一样,有的补符号位(算术右移),有的补0(逻辑右移)

C/C++ 各进制赋值、int/char转换、sscanf/sprintf、位操作运算的更多相关文章

  1. Java 整数型的进制间的互相转换

    /** * 整数型, 进制间的互相转换 */ public class IntConversion { public static void main(String[] args) { int num ...

  2. c# 16进制转int

    //十进制转二进制Convert.ToString(69, 2); //69为被转值//十进制转八进制Convert.ToString(69, 8); //69为被转值//十进制转十六进制Conver ...

  3. Java中byte与16进制字符串的互相转换

    * Convert byte[] to hex string.这里我们可以将byte转换成int,然后利用Integer.toHexString(int)来转换成16进制字符串. * @param s ...

  4. [转]Java中byte与16进制字符串的互相转换

    Java中byte用二进制表示占用8位,而我们知道16进制的每个字符需要用4位二进制位来表示(23 + 22 + 21 + 20 = 15),所以我们就可以把每个byte转换成两个相应的16进制字符, ...

  5. 进制与ASCII码转换

    LabeledEdit4.Text := chr(); // 用十进制方式赋值: ASCII码转换为字符 65 -> A LabeledEdit4.Text := #; // 用十进制方式赋值: ...

  6. Java Hex 16进制的 byte String 转换类

    package mobi.dzs.android.util; import java.util.Locale; /** * 16进制值与String/Byte之间的转换 * @author Jerry ...

  7. 字符串/16进制/ASCII码的转换

    1 /// <字符串转16进制格式,不够自动前面补零> 2 /// 假设文本框里面填写的是:01 02 03 04 05 06 3 /// Str获取的是01 02 03 04 05 06 ...

  8. python中2进制、10进制、16进制等之间的转换

    10转2: bin(8) # '0b1000' 2转10: int( 10转16: hex(15) # '0xf' 16转10: int( 2进制和16进制中间通过转10进制可以相互转换 from b ...

  9. PHP中进制之间的互相转换

    常见的进制: 二进制   binary   ----->  bin 八进制   octal     ----->  oct 十进制   decimal ----->  dec 十六进 ...

随机推荐

  1. TCP/IP具体解释--TCP/IP可靠的原理 滑动窗体 拥塞窗体

    TCP和UDP处在同一层---运输层,可是TCP和UDP最不同的地方是,TCP提供了一种可靠的数据传输服务,TCP是面向连接的,也就是说,利用TCP通信的两台主机首先要经历一个"拨打电话&q ...

  2. 前端预览图片和H5canvas压缩图片上传

    思路是将图片抽样显示在canvas上,然后用通过canvas.toDataURL方法得到base64字符串来实现压缩. 1.base64转二进制文件 /** * dataURL to blob, re ...

  3. HDU4185 Oil Skimming —— 最大匹配

    题目链接:https://vjudge.net/problem/HDU-4185 Oil Skimming Time Limit: 2000/1000 MS (Java/Others)    Memo ...

  4. YTU 2837: 编程题B-狐狸算卦

    2837: 编程题B-狐狸算卦 时间限制: 1 Sec  内存限制: 128 MB 提交: 76  解决: 52 题目描述 注:本题只需要提交需要完善部分的代码,请按照C++方式提交. 小熊和狐狸是邻 ...

  5. gearcache在qemu-kvm虚拟化平台下的实现

    需要用到的数据结构: 链表,基树. gearcache在qemu-kvm虚拟化平台下的实现主要有以下的步骤: 1.打开镜像文件的时候,为gearcache中的基数池(page_node_pool)和读 ...

  6. JAVA web简单的登录界面jsp实现

    此次试验所用到的软件是myeclipse10,tomcat7,Dreamweaver,sqlserver2008数据库.可以实现用户使用用户名和密码登录.如果登录成功,页面会显示登录成功,如果密码错误 ...

  7. java的内部类解析

    内部类分为四种: 成员内部类.类方法与普通方法同级: 局部内部类.类方法内部,局部内部类有构造器,通过构造器把外部的变量传入局部内部类再使用是完全可以的 匿名内部类.匿名内部类是唯一没有构造器的类,和 ...

  8. codeforces 125 A-E 补题

    A Measuring Lengths in Baden 进制转换 水题 #include<bits/stdc++.h> using namespace std; int main() { ...

  9. list:[::5]

    0-99的数列 L = [0, 1, 2, 3, ..., 99] 所有数,每5个取一个 >>> L[::5] [0, 5, 10, 15, 20, 25, 30, 35, 40, ...

  10. bzoj3160

    fft+manacher fft都快忘了... 其实我们发现,这个问题是可以用fft做的,因为是回文子序列,所以我们直接自己和自己求卷积,然后扫描每个位置,注意是每个位置,因为包括奇数长度和偶数长度, ...