C程序设计语言练习 第二章
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程序设计语言练习 第二章的更多相关文章
- Java语言程序设计(基础篇)第二章
第二章 基本程序设计 2.2 编写简单的程序 1.变量名尽量选择描述性的名字(descriptive name). 2.实数(即带小数点的数字)在计算机中使用一种浮点的方法来表示.因此,实数也称为浮点 ...
- C程序设计语言(第二版)习题:第一章
第一章虽然感觉不像是个习题.但是我还是认真去做,去想,仅此而已! 练习 1-1 Run the "hello, world" program on your system. Exp ...
- 最小正子序列(序列之和最小,同时满足和值要最小)(数据结构与算法分析——C语言描述第二章习题2.12第二问)
#include "stdio.h" #include "stdlib.h" #define random(x) (rand()%x) void creat_a ...
- win32多线程程序设计笔记(第二章)
第二章线程的第一次接触,主要讲了如何创建线程以及需要注意的几点. 一.创建线程 与调用函数的过程类似;线程只不过用CreateThread的API将函数封装起来,并产生一个与主程序同时执行的程序来调用 ...
- C程序设计语言笔记-第一章
The C Programming language notes 一 基础变量类型.运算符和判断循环 char 字符型 character ...
- C程序设计语言(第二版)习题:第二章
这一章习题做着很舒服,毕竟很简单.所以很有感觉. 练习 2-1 Write a program to determine the ranges of char , short , int , and ...
- 《python语言程序设计》_第二章笔记之2.13_软件开发流程
#程序1: 设计:由用户键入利率.贷款数以及贷款的年限,系统计算出每月还贷数和总还款数 注意:输入的年利率是带有百分比的数字,例如:4.5%.程序需要将它除以100转换成小数.因为一年有12个月,所以 ...
- 《python语言程序设计》_第二章笔记
#2.2_编写一个简单的程序 项目1: 设计:radius=20,求面积area? 程序: radius=20 #给变量radius复制area=radius*radius*3.14159 #编写ar ...
- 《python语言程序设计》_第二章编程题
2.1 程序: Celsius=eval(input("Enter a degree in Celsius:"))#输入摄氏度的值Celsiusfahrenheit =(9/5)* ...
随机推荐
- rpmlint 方便的rpm spec 以及rpm 文件检查工具
rpmlint 可以方便的让我们检查rpm spec 的信息,给予我们提示以及改进,同时也支持对于rpm 文件处理 安装 yum install -y rpmlint 使用 spec 检查 rpmli ...
- 在Matlab中的tick可以调整方向
需要将axis对话框的More property打开,修改TickDir,可从In改成Out.
- C Primer Plus--位操作
位字段 bit field 位字段是一个signed int或者unsigned int中一组相邻的位.位字段由一个结构声明建立,该结构声明为每个字段提供标签,并决定字段的宽度. struct p { ...
- Lomok @Data使用
看了廖师兄的Springboot视频发现很多很好玩的小工具,lombok就是其中一个.lombok是一个可以通过简单的注解的形式来帮助我们简化消除一些必须有但显得很臃肿的 Java 代码的工具,简单来 ...
- 在Visual Studio中直接编译Fluent的UDF
VS版本:Visual Studio 2013 Fluent版本:Fluent18.2 首先我们启动VS Studio中直接编译Fluent的UDF" title="在Visual ...
- socket http tcp ip 区别联系
功能是实现继承复用.刚才做了一个简要的概述,里面有一些常用的概念,这里做个简短的概念普及介绍:(1),TCP/IP------TPC/IP协议是传输层协议,主要解决数据如何在网络中传输.(2),Soc ...
- 2019暑假Java学习笔记(二)
目录 基础语法(下) 流程控制 if语句 switch语句 while语句和do-while语句 for语句 break关键字 continue关键字 数组 一维数组 二维数组 用户输入操作 练习题: ...
- 【Tensorflow】tf.nn.depthwise_conv2d如何实现深度卷积?
版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/mao_xiao_feng/article/ ...
- 【Qt开发】vs2017+qt5.x编译32位应用
概述 最近有同学私信我,问如何使用vs2017+qt5.10编译出32位的应用,需要使用msvc2017_x86的插件,然而qt官网并没有提供,只能使用源码编译生成msvc2017_x86插件,使用n ...
- cesium常用设置【转】
https://blog.csdn.net/D_Walker/article/details/82188514 1.加载线上cesium代码<link href="http://ces ...