2.3 常量

strlen函数:返回s的长度

int strlenn(char s[])
{
int i=0;
while(s[i] != '\0')
++i;
return i;
}

2.7 类型转换

atoi函数:将字符串s转换为相应的整型

int atoi(char s[])
{
int n = 0;
for (int i = 0; s[i] >= '0' && s[i] <= '9'; i++)
n = 10*n + (s[i] - '0');
return n;
}

lower函数:把字符c转换为小写形式,只对ASCII字符集有效

int lower(int c)
{
if(c >= 'A' && c <= 'Z')
return c + 'a' -'A';
else
return c;
}

rand函数:返回取值在0~32767之间的伪随机数,\(2^{15}\) = 32768

srand函数:为rand()函数设置种子数

unsigned long  int next = 1;

int rand()
{
next = next*1103515245 + 12345;
return (unsigned int)(next/65536)%32768;
} void srand(unsigned int seed)
{
next = seed;
}

练习2-3

编写函数htoi(s), 把由十六进制数字组成的字符串(包含可选的前缀0x或0X)转换为与之等价的整型值。字符串中允许包含数字包括:09,af以及A~F。

int htoi(char s[])
{
int n = 0,i = 0;
if(s[0] == '0' && (s[1] == 'x' || s[1] == 'X')) i = 2; for(; s[i] != '\0'; ++i) {
if(s[i] >= '0' && s[i] <= '9')
n = 16*n + (s[i] - '0');
else if(s[i] >= 'a' && s[i] <= 'f')
n = 16*n + (s[i] - 'a' + 10);
else if(s[i] >= 'A' && s[i] <= 'F')
n = 16*n + (s[i] - 'A' + 10);
else break;
}
return n;
}

2.8 自增运算符与自减运算符

squeeze函数:从字符串s中删除字符

void squeeze(char s[], char c)
{
int i,j;
for(i=j=0; s[i] != '\0'; ++i)
if(s[i] != c) //当不相等时才赋值,否则忽略
s[j++] = s[i];
s[j] = '\0';
}

strcat函数:将字符串t连接到字符串s的尾部;s必须有足够大的空间

void strcatt(char s[], char t[])
{
int i=0,j=0;
while(s[i] != '\0')
++i;
while((s[i++] = t[j++]) != '\0')
;
}

练习2-4

重写函数squeeze(s1,s2),将字符串s1中任何与字符串s2中字符匹配的字符都删除。

void squeeze2(char s1[], char s2[])
{
int i,j,z;
for(i=j=0; s1[i] != '\0'; ++i) {
for(z=0; s2[z] != '\0'&& s1[i] != s2[z]; ++z)
;
if(s2[z] == '\0') s1[j++] = s1[i]; //s2没有与之相等的字符
}
s1[j] = '\0';
}

练习2-5

编写函数any(s1,s2),将字符s2中的任一字符在字符串s1中的第一次出现的位置作为结果返回。如果s1中不包含s2中的字符,则返回-1。(标准库函数strpbrk具有同样的功能,但它返回的是指向该位置的指针。)

int any(char s1[], char s2[])
{
int i,j; for(i=0; s1[i] != '\0'; ++i) {
for(j=0; s2[j] != '\0' && s1[i] != s2[j]; ++j)
;
if(s2[j] != '\0') return i; //发现s2有相等字符
}
return -1;
}

2.9 按位运算符

getbits 函数:返回x中第p位开始的n位, 如getbits(x,4,3) 返回4,3,2位

unsigned getbits(unsigned x, int p, int n)
{
return (x >> (p-n+1)) & ~(~0 << n);
}

2.10 赋值运算符与表达式

bitcount函数:统计x中值位1的二进制位数

int bitcount(unsigned x)
{
int b;
for(b=0; x!= 0; x >>= 1)
if(x & 01)
++b;
return b;
}

练习2-9

在求对2的补码时,表达式x &= (x-1)可以删除x中最右边值为1的一个二进制位。请解释这样做的道理。用这一方法重写bitcount函数,以加快其执行速度

int bitcount(unsigned x)
{
int b;
for(b=0; x!= 0; x &= (x-1))
++b;
return b;
}

练习 2-10

重新编写将大写字母转换为小写字母的函数lower,并用条件表达式替代其中的if-else结构

int lower(int c)
{
return (c >= 'A' && c <= 'Z') ? c + 'a' - 'A' : c;
}

C程序设计语言练习 第二章的更多相关文章

  1. Java语言程序设计(基础篇)第二章

    第二章 基本程序设计 2.2 编写简单的程序 1.变量名尽量选择描述性的名字(descriptive name). 2.实数(即带小数点的数字)在计算机中使用一种浮点的方法来表示.因此,实数也称为浮点 ...

  2. C程序设计语言(第二版)习题:第一章

    第一章虽然感觉不像是个习题.但是我还是认真去做,去想,仅此而已! 练习 1-1 Run the "hello, world" program on your system. Exp ...

  3. 最小正子序列(序列之和最小,同时满足和值要最小)(数据结构与算法分析——C语言描述第二章习题2.12第二问)

    #include "stdio.h" #include "stdlib.h" #define random(x) (rand()%x) void creat_a ...

  4. win32多线程程序设计笔记(第二章)

    第二章线程的第一次接触,主要讲了如何创建线程以及需要注意的几点. 一.创建线程 与调用函数的过程类似;线程只不过用CreateThread的API将函数封装起来,并产生一个与主程序同时执行的程序来调用 ...

  5. C程序设计语言笔记-第一章

     The C Programming language notes 一 基础变量类型.运算符和判断循环         char                 字符型  character      ...

  6. C程序设计语言(第二版)习题:第二章

    这一章习题做着很舒服,毕竟很简单.所以很有感觉. 练习 2-1 Write a program to determine the ranges of char , short , int , and ...

  7. 《python语言程序设计》_第二章笔记之2.13_软件开发流程

    #程序1: 设计:由用户键入利率.贷款数以及贷款的年限,系统计算出每月还贷数和总还款数 注意:输入的年利率是带有百分比的数字,例如:4.5%.程序需要将它除以100转换成小数.因为一年有12个月,所以 ...

  8. 《python语言程序设计》_第二章笔记

    #2.2_编写一个简单的程序 项目1: 设计:radius=20,求面积area? 程序: radius=20 #给变量radius复制area=radius*radius*3.14159 #编写ar ...

  9. 《python语言程序设计》_第二章编程题

    2.1 程序: Celsius=eval(input("Enter a degree in Celsius:"))#输入摄氏度的值Celsiusfahrenheit =(9/5)* ...

随机推荐

  1. Can't generate API documentation in l5-swagger

    Can't generate API documentation in l5-swagger Ask Question Asked 3 months ago Active 1 month ago Vi ...

  2. rollup node.js 打包工具

    最近在做一个提供给浏览器和node同时使用的js的url模板工具类,在用什么打包工具上纠结了一段时间,正好有一天在知乎上看到了关于rollup的介绍,在自己试了试之后,就决定用rollup.js来打包 ...

  3. 安卓入门教程(十三)-Activity

    已经发表个人公众号 什么是Activity? Android是由Activity,Service,Content,Provider等组件组成,其中要讲的就是Activity组件,这是最基本,且常用的组 ...

  4. mysql ltrim() 函数

    mysql> select " dedede"; +----------+ | dedede | +----------+ | dedede | +----------+ r ...

  5. hbase 监控指标项

    名词解释 JMX:Java Management Extensions,用于用于Java程序扩展监控和管理项 GC:Garbage Collection,垃圾收集,垃圾回收机制 指标项来源 主机名 u ...

  6. 京东购物车的Java架构实现及原理!

    今天来写一下关于购物车的东西, 这里首先抛出四个问题: 1)用户没登陆用户名和密码,添加商品, 关闭浏览器再打开后 不登录用户名和密码 问:购物车商品还在吗? 2)用户登陆了用户名密码,添加商品,关闭 ...

  7. Linux+Apache环境下安装SSL证书

    一.安装证书 (温馨提示:安装证书前请先备份您需要修改的服务器配置文件) 1.确认证书文件及证书路径.  例证书文件为:zzidc.com.jks,放置目录为Tomcat的conf目录下.  2.配置 ...

  8. HTTP与RPC(Thrift)

    什么是RPC 从网络协议来说,Http协议与Rpc同属于应用层, 他们的底层都是tcp协议. RPC(即Remote Procedure Call,远程过程调用)和HTTP(HyperText Tra ...

  9. 【软工实践】Beta版本演示

    团队信息 队名:女生都队 组长博客: 博客链接 成员 学号 史恩泽(组长) 031702122 施金海 031702121 阮君曦 031702116 陈银山 031702137 李季城 031702 ...

  10. springboot 整合rabbitMQ

    RabbitMQ RabbitMQ是一个被广泛使用的开源消息队列.它是轻量级且易于部署的,它能支持多种消息协议.RabbitMQ可以部署在分布式和联合配置中,以满足高规模.高可用性的需求. 在pom. ...