找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3402|回復(fù): 2
收起左側(cè)

求教unsigned char code buf[20],寫一段C程序指出數(shù)組中的最大值

[復(fù)制鏈接]
ID:105996 發(fā)表于 2016-5-28 10:10 | 顯示全部樓層 |閱讀模式
unsigned char code buf[20],寫一段C程序指出數(shù)組中的最大值,如buf[5]中,最大的是5.
回復(fù)

使用道具 舉報

ID:111634 發(fā)表于 2016-5-28 14:12 | 顯示全部樓層
本程序摘自張志良編著著《單片機實驗實訓(xùn)100例——基于Keil C和Proteus》 ISBN 978-7-5124-1603-1北航出版社。



從串口隨機輸入16個數(shù)據(jù),然后再從串口分二行分別輸出其排序前后的數(shù)據(jù)。


#include <reg51.h>                       //包含訪問sfr庫函數(shù)reg51.h


#include <stdio.h>                       //包含I/O庫函數(shù)stdio.h


#define  uchar unsigned char             //uchar表示unsigned char


void  main ( ) {                         //主函數(shù)


uchar data  i,j,k,m;                     //定義字符型變量ij、k(最大值序號)、m(暫存器)


uchar data  a[16];                      //定義整型數(shù)組a[16]


TMOD=0x20;                         //串口初始化:定時器1工作方式2;


TH1=TL1=0xE6;                      //1200波特率(fosc=12MHz


SCON=0x52;                         //串口方式1,允許接收,清發(fā)送中斷


TCON=0x40;                         //設(shè)置中斷控制,啟動T1


for(i=0; i<16; i++)                     //for循環(huán)


scanf("%bu",a+i);                    //串口輸入數(shù)組a數(shù)據(jù)(無符號字符型十進制整數(shù))


for(i=0; i<16; i++) {                   //for循環(huán)


if (i%8==0)  printf("\n");              //i8的整倍數(shù),換行(輸出時,8個一行)


printf ("a[%bu]=%bu,",i,a);}          //輸出數(shù)組a原始數(shù)據(jù)元素


for(i=0; i<15; i++) {                   //for循環(huán),選擇法排序


k=i;                               //最大值序號k賦值,設(shè)最大值為首個元素


for(j=i; j<16; j++)                   //for循環(huán),依次與后續(xù)數(shù)組元素比較,選出最大值


if (a[k]<a[j]) k=j;                 //比較,若a[k] <a[j],最大值序號變更


m=a[k];a[k]=a;a=m;}              //交換位置


printf ("\n");                          //換行


for(i=0; i<16; i++) {                   //for循環(huán)


if (i%8==0)  printf("\n");             //i8的整倍數(shù),換行(輸出時,8個一行)


printf ("a[%bu]=%bu,",i,a);}          //輸出從大到小排序后數(shù)組a的數(shù)據(jù)元素


while(1);}                            //原地踏步,無限循環(huán)


回復(fù)

使用道具 舉報

ID:111634 發(fā)表于 2016-5-28 14:16 | 顯示全部樓層
⒉ Keil調(diào)試



實例1所述步驟,編譯鏈接并進入調(diào)試狀態(tài)。


鼠標左鍵單擊調(diào)試工具條中圖標(   ),打開變量觀測窗口,Locals標簽頁中顯示局部變量i、jk、ma,其中a為數(shù)組,編譯器安排其首地址為0x24。


鼠標左鍵單擊調(diào)試工具條中圖標(   ),打開存儲器窗口。在Memory#1窗口的Address編輯框內(nèi)鍵入“d0x24”,以便觀測內(nèi)RAM 24H為首地址的數(shù)組a中的數(shù)據(jù)。


鼠標左鍵單擊全速運行圖標(   ),暫停圖標(   )變?yōu)榧t色。


鼠標左鍵單擊調(diào)試工具條中圖標(   ),打開串行輸入/輸出信息窗口Serial #1。窗口內(nèi)光標閃爍(表示被激活),依次鍵入數(shù)組a的原始數(shù)據(jù):


a[16]={11,99,66,22,111,55,0,222,44, 155,77,255,133,100,88,33}


注意每鍵入一個數(shù)據(jù),均要回車一次;剀嚭,Memory#1窗口內(nèi)0x24及其后續(xù)單元依次顯示鍵入的數(shù)組a元素。最后一個數(shù)據(jù)鍵入完畢,回車后,Serial #1窗口立即顯示數(shù)組a原始數(shù)據(jù)和排序后的數(shù)據(jù)。前二行是排序前的原始數(shù)據(jù),后二行是排序后的數(shù)據(jù):


a[0]=11,a[1]=99,a[2]=66,a[3]=22,a[4]=111a[5]=55,a[6]=0,a[7]=222,


a[8]=44a[9]=155,a[10]=77,a[11]=255,a[12]=133,a[13]=100,a[14]=88a[15]=33,


a[0]=255a[1]=222,a[2]=155,a[3]=133,a[4]=111a[5]=100,a[6]=99,a[7]=88,


a[8]=77,a[9]=66,a[10]=55a[11]=44,a[12]=33a[13]=22,a[14]=11a[15]=0,


與此同時,Memory#1窗口以0x24為首地址的16個單元內(nèi),也改為排序后的數(shù)組a數(shù)據(jù)。


回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表