2301_76756206 2023-03-15 16:10 采纳率: 50%
浏览 14
已结题

我想问下,这是个测量距离的代码,怎么让他每当如果先有g=15,再有g=20则h加一,如果先有g=20,再有g=15则f加一。

我想问下,这是个测量距离的代码,怎么让他每当如果先有g=15,再有g=20则h加一,如果先有g=20,再有g=15则f加一。

void Timer0() interrupt 1
{
    unsigned long i=0,j,g;
static unsigned long last_i = 0;
static unsigned long  h = 1; // ???h?1
static unsigned long  f = 1;
    if(time<10)//0.5s
        time++;
    else 
    {
        time=0;
        i=mcp_read();//²âÁ¿
        i=i*1135/2907;
        disp1[0]=i/100000+0x30;
        disp1[1]=i%100000/10000+0x30;
        disp1[2]=i%10000/1000+0x30;
        disp1[3]=i%1000/100+0x30;
        disp1[5]=i%100/10+0x30;
        disp1[6]=i%10+0x30;
        write_string(1,0,disp1);
        //计算距离
        j=(204657-i);
        j=j*10/69+10000;
        i=j;
        t[0]=i/10000+0x30;
        t[1]=i%10000/1000+0x30;
        t[2]=i%1000/100+0x30;
        t[4]=i%100/10+0x30;
        t[5]=i%10+0x30;
        g=i/1000;
        write_string(2,0,t);

  • 写回答

2条回答 默认 最新

  • 丘比特惩罚陆 2023-03-15 16:17
    关注
    
    if (g == 15 && last_i == 20) {
        h++;
    } else if (g == 20 && last_i == 15) {
        f++;
    }
    last_i = g;
    

    这段代码检查变量g是否为15或20,同时检查上一次的变量last_i是否为15或20。如果g等于15且last_i等于20,则h增加1;如果g等于20且last_i等于15,则f增加1。最后,将last_i设置为当前的g值。

    完整的应该是这样的:你可以试一下,有用的话给我点个关注,没有的话,当我放了个屁,哈哈哈!

    void Timer0() interrupt 1
    {
        unsigned long i=0,j,g;
        static unsigned long last_i = 0;
        static unsigned long h = 1; // h初始化为1
        static unsigned long f = 1; // f初始化为1
        if(time<10) //0.5s
            time++;
        else 
        {
            time=0;
            i=mcp_read(); // 读取模拟量信号
            i=i*1135/2907;
            disp1[0]=i/100000+0x30;
            disp1[1]=i%100000/10000+0x30;
            disp1[2]=i%10000/1000+0x30;
            disp1[3]=i%1000/100+0x30;
            disp1[5]=i%100/10+0x30;
            disp1[6]=i%10+0x30;
            write_string(1,0,disp1);
            // 计算距离
            j=(204657-i);
            j=j*10/69+10000;
            i=j;
            t[0]=i/10000+0x30;
            t[1]=i%10000/1000+0x30;
            t[2]=i%1000/100+0x30;
            t[4]=i%100/10+0x30;
            t[5]=i%10+0x30;
            g=i/1000;
            write_string(2,0,t);
            if (
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月23日
  • 已采纳回答 3月15日
  • 创建了问题 3月15日

悬赏问题

  • ¥20 易康econgnition精度验证
  • ¥15 msix packaging tool打包问题
  • ¥28 微信小程序开发页面布局没问题,真机调试的时候页面布局就乱了
  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败