找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2928|回復: 0
打印 上一主題 下一主題
收起左側

請教,隨機排布函數的設計

[復制鏈接]
跳轉到指定樓層
樓主
ID:50562 發(fā)表于 2013-5-26 14:01 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
隨機排布:任一順序的0~9的排列,如:8,3,1,5,4,0,9,7,6,2
用單片機生成一個隨機排列,然后輸出到P2口。
請大神指點啊
程序(有問題)如下:
#include<stdio.h>
#include<REG52.H>
unsigned short rtab[10] = {3, 9, 4, 1, 5, 0, 7, 8, 2, 6};
unsigned short divider[9] = {2, 3, 5, 7, 11, 13, 17, 19, 23};   
unsigned short skip[9] = {0, 0, 0, 0, 0, 0, 0, 0, 0};      //skip是在rtab中的偏移
unsigned short temp[9] = {0, 0, 0, 0, 0, 0, 0, 0, 0};      //暫存skip
unsigned short result[10] = {0, 0, 0, 0, 0, 0, 0, 0, 0};   //存放隨機排布
unsigned int count=1;
void test()        //如果count能夠被divider整除,那么skip++。
{
int i;
for(i=0;i<=8;i++)
{
  if(count%divider==0)
  {
   if(skip>=9-i)   //skip[]的進制分別是10,9,8,.....,3,2
    skip=0;
   else
    skip++;
   break;
  }
}
}
void timer1_int() interrupt 3 using 2     //計時器1中斷程序,令count非溢出地加1
{
if(count>=65531)
  count=1;
else
  count++;
test();
}
void swap(unsigned short x,unsigned short y)   //將x,y對換
{
unsigned short tep;
tep=x;
x=y;
y=tep;
}
void refresh()                     //刷新,產生隨機排布result[10];
{
//TR1 = 0;
int i=0;
for(i=0; i<=8; i++ )
  temp=skip;
//TR1=1;
   
for(i=0;i<=8;i++)                        //問題:該循環(huán)中,swap()不能實現(xiàn)rtab[temp]與rtab[9-i]的對換
{
  result=rtab[temp];
  swap(rtab[temp],rtab[9-i]);  //保證下次取到的數rtab[temp[i+1]]不與已經取到的數result[0~i]重復
}
result=rtab[0];
}
void display()                  //將result數組的內容依次輸出到P2口                    
{
int i;
for(i=0; i<=9;i++ )
{
  P1=i;
  P2=result;
}
}
void int0_service() interrupt 2 using 3    //有鍵被按下時,調用外部中斷1程序
{
switch(P1)
{
  case'0':
  case'1':
  case'2':
  case'3':
  case'4':
  case'5':
  case'6':
  case'7':
  case'8':
  case'9':P2=P1;/*save(P1);*/refresh();display();break;
// case'c':clear();break;                                 //清除一位
  case'r':refresh();display();break;                     //刷新
// case'e':enter();P2=enter;break;                       //確定
  default:/*P2=error;*/break;                          //顯示出錯
}
}

void main()
{

TMOD |= 0x20;             //timer 1, mode 2, 8-bit reload
TH1   = 221;              //初始值
EA    = 1;                //開所有中斷
ET1   = 1;                //開計時器1溢出中斷
EX1   = 1;                //開外部中斷1
PX1   = 1;                //設外部中斷1為高優(yōu)先級
PT1   = 0;                //設計時器1中斷為低優(yōu)先級
TR1   = 1;                //計時開始

    while(1)                  //當按下確定鍵時,開始程序
{
  if(P1=='e')
   break;
}
refresh();               
while(1)
{
  display();
}
}

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

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

本版積分規(guī)則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表