《C和指针》章节后编程练习解答参考——第8章
8.1
#include <stdio.h> int main (void)
{
int a, b, c, d; // 不使用嵌套花括号初始化
unsigned char char_value[][][][] =
{
, , , , , , , , , , , , , , , , , , , , // 0,0,X,X
, , , , , , , , , , , , , , , , , , , , // 0,1,X,X
, , , , , , , , , , , , , , , , , , , ,
, , , , , , , , , , , , , , , , , , , ,
, , , , , , , , , , , , , , , , , , , ,
, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , // 1,0,X,X
, , , , , , ' ', , , , , , , , , , , , , , // 1,1,X,X
, , , , , , , , , , , , , 'A', , , , , , 'x',
, , , , , , , , , , , , 0xf3, , , , , , , ,
, , , , , , , , , , , , , '\n', , , , , , ,
, , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , // 2,0,X,X
, , , , , , , , , , , , , , , , , , , , // 2,1,X,X
, , , , , , '', , , , , , '\'', , , , '\121', , , ,
, , , , , , , , , , , , , , , , , , , ,
, , , , , , , , , , , , , , , , , '', , ,
, , , , , , , , , , , , , , , , , , , ,
}; /*
// 使用嵌套花括号初始化
unsigned char char_value[3][6][4][5] =
{
{ //0,X,X,X
{ //0,0,X,X
{ 0 }, //0,0,0,X
}
},
{ //1,X,X,X
{ 0 }, //1,0,X,X
{ //1,1,X,X
{ 0 }, //1,1,0,X
{ //1,1,1,X
0, ' '
}
},
{ //1,2,X,X
{ 0 }, //1,2,0,X
{ 0 }, //1,2,1,X
{ 0, 0, 0, 'A' },//1,2,2,X
{ //1,2,3,X
0, 0, 0, 0, 'x'
}
},
{ //1,3,X,X
{ 0 }, //1,3,0,X
{ 0 }, //1,3,1,X
{ //1,3,2,X
0, 0, 0xf3
}
},
{ //1,4,X,X
{ 0 }, //1,4,0,X
{ 0 },//1,4,1,X
{ //1,4,2,X
0, 0, 0, '\n'
}
}
},
{ //2,X,X,X
{ 0 }, //2,0,X,X
{ //2,1,X,X
{ 0 }, //2,1,0,X
{ //2,1,1,X
0, 0, 0320
}
},
{ //2,2,X,X
{ 0 }, //2,2,0,X
{ //2,2,1,X
0, '0'
},
{ //2,2,2,X
0, 0, '\''
},
{ //2,2,3,X
0, '\121'
}
},
{ 0 }, //2,3,X,X
{ //2,4,X,X
{ 0 }, //2,4,0,X
{ 0 }, //2,4,1,X
{ 0 }, //2,4,2,X
{ //2,4,3,X
0, 0, '3', 3
}
},
{ //2,5,X,X
{ 0 },//2,5,0,X
{ 0 },//2,5,1,X
{ 0 },//2,5,2,X
{ //2,5,3,X
0, 0, 0, 0, 125
}
}
}
};
*/ for ( a = ; a < ; a++ )
for ( b = ; b < ; b++ )
for ( c = ; c < ; c++ )
for ( d = ; d < ; d++ )
{
if ( char_value[a][b][c][d] != )
printf("char_value[%d][%d][%d][%d] = %d\n", a, b, c, d, char_value[a][b][c][d]);
} getchar();
return ;
}
8.3
#include <stdio.h> #define N 3 #define TRUE 1
#define FLASE 0 int
identity_matrix(int mat[][N])
{
int i, j;
for( i = ; i < N; i++)
{
for( j = ; j < N; j++)
{
if ( ( i == j ) && ( != mat[i][j] ) )
return FLASE;
if ( ( i != j ) && ( != mat[i][j] ) )
return FLASE;
}
}
return TRUE;
} void show_mat(int mat[][N])
{
int i, j;
for ( i = ; i < N; i++)
{
for( j = ; j < N; j++)
{
printf("%d\t", mat[i][j]);
}
putchar('\n');
}
} int main (void)
{
int mat[][N] =
{
{ },
{ , },
{ , , }
}; int state = identity_matrix(mat);
show_mat(mat); if ( state )
{
printf("Yes!\n");
}
else
printf("No!\n"); getchar();
return ;
}
8.4
#include <stdio.h> #define N 3 #define TRUE 1
#define FLASE 0 int identity_matrix(int *mat, int n) //判断矩阵是否为单位矩阵
{
int i, j;
for( i = ; i < n; i++)
{
for( j = ; j < n; j++)
{
if ( ( i == j ) && ( != *mat ) )
return FLASE;
if ( ( i != j ) && ( != *mat ) )
return FLASE;
mat++;
}
}
return TRUE;
} void show_mat(int *mat, int n) //打印矩阵元素
{
int i, j; for ( i = ; i < n; i++)
{
for( j = ; j < n; j++)
{
printf("%d\t", *mat++);
}
putchar('\n');
}
} int main (void)
{
int mat[][N] =
{
{ },
{ , },
{ , , }
}; int state = identity_matrix( &mat[][], N);
show_mat(&mat[][], N); if ( state )
{
printf("Yes!\n");
}
else
printf("No!\n"); getchar();
return ;
}
8.5
#include <stdio.h> #define X 3
#define Y 2
#define Z 4 void matrix_multiply(int *m1, int *m2, int *r, int x, int y, int z)
{
int i, j, k, sum; for ( i = ; i < x; i++ )
{
for ( k = ; k < z; k++ )
{
sum = ;
for ( j = ; j < y; j++ )
{
sum += (*(m1+(i*y)+j)) * (*(m2+(j*z+k)));
}
*( r + (i*z) + k ) = sum;
}
}
} void show_mat(int *mat, int x, int y) //打印矩阵元素
{
int i, j; for ( i = ; i < x; i++)
{
for( j = ; j < y; j++)
{
printf("%d\t", *mat++);
}
putchar('\n');
}
putchar('\n');
} int main (void)
{
int m1[X][Y] =
{
{ , - },
{ , },
{ , - }
}; int m2[Y][Z] =
{
{ , -, -, - },
{ -, -, , }
}; int r[X][Z] = { }; printf("m1 = \n");
show_mat(&m1[][], X, Y);
printf("m2 = \n");
show_mat(&m2[][], Y, Z); matrix_multiply(&m1[][], &m2[][], &r[][], X, Y, Z);
printf("r = m1 * m2 = \n");
show_mat(&r[][], X, Z); getchar();
return ;
}
《C和指针》章节后编程练习解答参考——第8章的更多相关文章
- 《C和指针》章节后编程练习解答参考——第5章
5.1 题目: 略 解答代码: #include <stdio.h> int main(void) { char ch; while (((ch = getchar()) != EOF) ...
- 《C和指针》章节后编程练习解答参考——第10章
10.1 #include <stdio.h> typedef struct { unsigned ]; unsigned ]; unsigned ]; }TelphoneNumber; ...
- 《C和指针》章节后编程练习解答参考——第9章
9.1 #include <stdio.h> #include <ctype.h> #include <string.h> #define N 100 int ma ...
- 《C和指针》章节后编程练习解答参考——6.2
<C和指针>——6.2 题目: 编写一个函数,删除源字符串中含有的子字符串部分. 函数原型: int del_substr(char *str, char const *substr); ...
- 《C和指针》章节后编程练习解答参考——6.3
<C和指针>——6.3 题目: 编写一个函数,把参数字符串中的字符反向排列. 函数原型: void reverse_string(char *string); 要求: 使用指针而不是数组下 ...
- 《C和指针》章节后编程练习解答参考——6.6
<C和指针>——6.6 题目: 在指定的下限.上限之间使用数组方法查找质数,并将质数提取出来. 要求: 略 解答代码: #include <stdio.h> #define U ...
- 《C和指针》章节后编程练习解答参考——6.4
<C和指针>——6.4 题目: 质数是只能被1和本身整除的整数. 在1到1000之间的质数,在数组中剔除不是质数的数. 解答代码: #include <stdio.h> #de ...
- 《C和指针》章节后编程练习解答参考——6.1
<C和指针>——6.1 6.1 题目: 编写一个函数,在一个字符串中进行搜索,查找另一子字符串中出现的字符. 函数原型如下: char *find_char(char const *sou ...
- DSAPI多功能组件编程应用-参考-Win32API常数
DSAPI多功能组件编程应用-参考-Win32API常数 在编程过程中,常常需要使用Win32API来实现一些特定功能,而Win32API又往往需要使用一些API常数,百度搜索常数值,查手册,也就成了 ...
随机推荐
- 用bat文件将本地sql在远程oracle上执行
最近在在搭建一个数据库的测试环境,需要初始化一些数据库脚本.因为内容比较多,分为很多个sql文件.现准备写一个bat文件,经过百度一番,终于搞定.如下: 1. 新建一个文件夹,将初始化的脚本文件全部放 ...
- PHP环境配置综合篇
1.WNMP: http://www.wnmp.com.cn/ En: https://www.getwnmp.org/ 2.xampp:https://www.apachefriends.o ...
- 通过rest接口获取自增id (twitter snowflake算法)
1. 算法介绍 参考 http://www.lanindex.com/twitter-snowflake%EF%BC%8C64%E4%BD%8D%E8%87%AA%E5%A2%9Eid%E7%AE% ...
- linux之access函数解析
[lingyun@localhost access_1]$ ls access.c 实例一: [lingyun@localhost access_1]$ cat access.c /******** ...
- Codeforces 114A-Cifera(暴力)
A. Cifera time limit per test 2 seconds memory limit per test 256 megabytes input standard input out ...
- 用apache的httpclient发请求和接受数据
此处发请求的是用httpclient4,请自己下载所需要的jar包. 发post请求,并得到数据. String url = "http://localhost:8080/lee" ...
- 浅谈Android自定义锁屏页的发车姿势
一.为什么需要自定义锁屏页 锁屏作为一种黑白屏时代就存在的手机功能,至今仍发挥着巨大作用,特别是触屏时代的到来,锁屏的功用被发挥到了极致.多少人曾经在无聊的时候每隔几分钟划开锁屏再关上,孜孜不倦,其酸 ...
- Android 自定义View修炼-Android开发之自定义View开发及实例详解
在开发Android应用的过程中,难免需要自定义View,其实自定义View不难,只要了解原理,实现起来就没有那么难. 其主要原理就是继承View,重写构造方法.onDraw,(onMeasure)等 ...
- JavaScript异步操作
//伪代码写法,只用来记录结构 function test(){ var dtd=$.Deferred(); if(成功){ dtd.resolve(data1,data2); //传递参数 } el ...
- JavaScript 是世界上最好的语言?
2016年1月中旬,Stack Overflow发起本年度的开发者调查,调查结果于近日公布.本文盘点 JS 开发者应该会关心的部分数据. Stack Overflow 技术排行榜: 在2015年6月, ...