.
3
3
3
用查表方式编写 y=x1 + x2 +x3 。(x 为 0~9 的整数)
#include
int code a[10]={0,1,8,27,64,125,216,343,512,729}; //将 0~9 对应的每位数字的三次方的值code为程序存储器,当所存的值在 0~255 或-128~+127 之间的话就用 char , 存入 code中,
而现在的值明显超过这个范围,用 int 较合适。 int 的范围是 0~65535 或-32768~32767 。
int y,x1,x2,x3; //此处定义根据习惯,也可写成 char x1,x2,x3 但是变量 y 一定要用 int 来
定义。
x1=2; x2=4;
x3=9; //x1,x2,x3 三个的值是自定的,只要是 0~9 当中的数值皆可,也可重复。 y=a[x1]+a[x2]+a[x3];
while(1); //单片机的程序不能停,这步就相当于无限循环的指令,循环的内容为空白。 }
//结果的查询在 Keilvision 软件内部,在仿真界面点击右下角(一般初始位置是右下角)的watch 的框架内双击“ double-click or F2 to add”文字输入 y 后按回车,右侧会显示其 16 进
制数值如 0x34,鼠标右键该十六进制,选择第一行的 decimal,可查看对应的 10 进制数。
1、 有 10 个 8 位二进制数据,要求对这些数据进行奇偶校验,凡是满足偶校验的
数据( 1 的个数为偶数) 都要存到内 RAM50H 开始的数据区中。 试编写有关程序。
#include
int a[10]={0,1,5,20,24,54,64,88,101,105}; // 将所要处理的值存入 RAM 中,这些可以根据
个人随意设定,但建议不要超过 0~255 的范围。
char i;
// 定义一个变量
// 定义一个指针 *q 指向内部 0x50 这个地址。
char *q=0x50; {
ACC=a[i]; //将 a[i] 的值赋给累加器 ACC
if (P==0) //PSW0 位上的奇偶校验位,如果累加器 ACC 内数值 1 的个数为偶数那么
P 为 0,若为奇数, P 为 1。这里的 P 是大写的。
{
*q=a[i];
q++; // 每赋一个值,指针挪一个位置指向下一个。 } }
while(1); //同实验一,程序不能停。 }
for(i=9;i>=0;i--) //9~0 循环,共十次,也可以用 for(i=0;i<10;i++)
;..
.
3. 有 10 个 8 位带符号二进制数, 请将 10 个数按从小到大的顺序排列, 并存到内
RAM50H 开始的单元中 。
#include
char data a[10]={-50,-36,0,-128,1,99,127,89,-89,40} unsigned char *q=0x50; unsigned char i,j; char t;
//定义三个变量,用于循环及换位。在换位时有赋值,所以
t 要用 char 不能用
unsigned char。
for(i=0;i<10;i++)
for(j=0;j<10-i;j++) //冒泡法,具体可以参考 C 语言程序设计的书。 {
if(a[j]>a[j+1]) {
t=a[j]; a[j]=a[j+1]; a[j+1]=t; }
;// 将所有值存入 RAM 中,因为有负
数,所以不能用 unsigned char。因为是 char 所以假设的数值不要超过 -128~+127 之外
//定义指针 *q 指向 0x50
}
for(i=0;i<10;i++) {
*q=a[i]; q++; } while(1);
}
// 将已经排好序的数组存入 *q 指向的地址。
1、基本部分:
( 1) P1 口做输出口,接八只发光二极管,编写程序,使发光二极管循环点亮。
#include
unsigned char i,j,k; do {
for(i=10;i>0;i--) for(j=100;j>0;j--) for(k=249;k>0;k--); }
// 定义延迟函数,用于后面 LED 灯亮的持续时间。
;..
.
while(--x);} main() {
P1=0xfe; //11111110第一个灯亮 while(1) {
delay(1);// 延时 500ms
P1=P1<<1|1;//P1 左移一个位即 11111101 具体 crol 跟<< 的区别与具体细节可联系
我与你讲解
if(P1==0XFF) { P1=0XFE; } } }
( 2)P1.0、P1.1 作输入口接两个拨动开关, P1.2、P1.3 作输出口,接两个发光二极管, 编写程序读取开关状态,将此状态,在发光二极管上显示出来。编程时应注意 P1.1 作为输入口时应先置
1,才能正确读入值。
P1.0、
#include
sbit p1_0=P1^0; sbit p1_1=P1^1; sbit p1_2=P1^2;
sbit p1_3=P1^3; //程序不能对单个引脚进行编程,需要用 sbit 定义才可用。 main() {
p1_0=1;p1_1=1;p1_2=1;p1_3=1; //前两个引脚置一是为了让其能获取输入信号, 后两个
引脚是赋初值,方便后面取反工作。
while(1) {
if(!p1_0) //判断 P1.0 的引脚是否有变化。 {
p1_2=!p1_2; }
if(!p1_1) //判断 P1.1 的引脚是否有变化。 {
p1_3=!p1_3; // 如果 P1.1 引脚变化, P1.3 引脚也跟随变化。 } } }
// 如果 P1.0 引脚变化, P1.2 引脚也跟随变化。
;..
.
2、扩展部分:
( 1) 利用 P1 口控制发光二极管 LED 灯按照下面方式工作:
a) b) c)
LED 灯从左到右依次点亮; LED 灯从右到左依次点亮;
按照以上步骤重复运行,其中要求灯亮的时间为
500ms。
#include
unsigned char i,j,k; do {
for(i=10;i>0;i--)
for(j=100;j>0;j--)
for(k=249;k>0;k--);
}while(--x); } main() { while(1) {
P1=0XFE; //右移完毕后赋初值,为左移做准备 delay(1); while(1) {
//无限循环里面的内容
P1=P1<<1; // 如果左移右移是单个灯移动的话, 那么这句改为 LED=LED<<1|1; delay(1);
if(P1==0x00) //判断左移是否完毕,完毕 break 跳出此次的 while break; } P1=0x7f; delay(1); while(1) {
P1=P1>>1; // 如 果 左 移 右 移 是 单 个 灯 移 动 的 话 , 那 么 这 句 改 为
// 左移完毕后给 P1 赋初值,准备右移
就可以了。
LED=LED>>1|0x80; 就可以了。
delay(1);
if(P1==0x00) // 判断右移是否完毕,完毕后 break 跳出 break; }
} }
;..
.
( 2) 利用 P1 口控制发光二极管 LED 灯按照下面方式工作:
a) 从左到右奇数 LED 灯依次点亮; b) 从右到左偶数 LED 灯依次点亮;
c) 按照以上步骤重复运行,其中要求灯亮的时间为
500ms。
#include
// 此程序也可以用 <<和>>来实现,具体细节可以来问我 // 当程序中有涉及到 _crol_ 或者_nop_等库函数时,必须添
加此头文件。
void delay(unsigned char x) {
unsigned char i,j,k; do {
for(i=10;i>0;i--)
for(j=100;j>0;j--)
for(k=249;k>0;k--);
}while(--x); } main() {
while(1) { P1=0xfe; while(1) {
delay(1); P1=_crol_(P1,2); if(P1==0xfe)
break;
} P1=0X7f; while(1) {
delay(1); P1=_cror_(P1,2); if(P1==0x7f)
break;
} } }
// 无限循环括号里的内容 // 第一个灯亮,
//P1 左移两个位置 // 判断左移结束
//P1 右移两个位置 // 判断右移结束
#include
// 延时函数 500ms
;..