0

我想以给定的输入顺序遍历循环链表(v1->v2->v3),比如说

{v1,v3,v2,v2,v1,v3,v2,v1,v1,v3,v2,v2,v1,v2,v3}.

我编写了以下程序作为 3 个节点的测试,并希望逐步扩展 8、64、512、4096 等节点。

我的实现想法要求以下程序仅在Abstract State Machine仅接受以下函数作为处理输入的程序上运行。我基本上想最小化engine_spin_at_gear()遍历时的循环计数。我可能处于non-blocking使用这种疯狂的模式abstraction来模拟/虚拟process-execution化为一个engine-spin以 rpm 为测量单位的模式,但我真的很想要关于调试该engine_spin_at_gear()功能的建议。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MILES 15

struct package
{
        // ... other members data ...
        struct package *next;
}*v1, *v2, *v3;

int input_arr[MILES] = {1,3,2,2,1,3,2,1,1,3,2,2,1,2,3};

struct package *base(struct package *_vN)
{
        if (_vN)
                return _vN;
        else
                return NULL;
}

struct package *deliver(struct package *_vNP)
{
        if (_vNP)
                return base(_vNP->next);
        else
                return NULL;
}

void shift_gear(struct package *_feed)
{
        _feed->next = NULL;
}

struct package *engine_spin_at_gear(struct package *_init_cycle0, int countSession)
{
        while (countSession--) {
                shift_gear(_init_cycle0);
                return deliver(base(_init_cycle0));
        }
        return NULL;
}

struct package *journey(struct package *_current_frame, int _start, int _end)
{
        int rpm = (_end > _start)?_end-_start:_start-_end;
        if (rpm)
                return engine_spin_at_gear(_current_frame, rpm);
        else
                return v1;
}

struct package *ignition_phase(int _batteryS, int _chargedL)
{
        return journey(v1, _batteryS, _chargedL);
}


void transmit_in_order(int*input_arr)
{
        struct package *v6;
        int i;

        for (i=0; i<MILES-1; i++) {
                v6 = ignition_phase(input_arr[i], input_arr[i+1]);
                printf("%p\n", v6);
        }
}

int main()
{
        v1 = malloc(sizeof(struct package));
        v2 = malloc(sizeof(struct package));
        v3 = malloc(sizeof(struct package));

        v1->next = v2;
        v2->next = v3;
        v3->next = v1;

        printf("v1=%p\tv2=%p\tv3=%p\n", v1, v2, v3);
        transmit_in_order(input_arr);
        return 0;
}

当我在 Linux 上运行程序的 GCC 可执行文件时,我得到以下输出。

v1=0x918b008    v2=0x918b018    v3=0x918b028
(nil)
(nil)
0x918b008
(nil)
(nil)
(nil)
(nil)
0x918b008
(nil)
(nil)
0x918b008
(nil)
(nil)
(nil)
(nil)

或者,我需要更改shift_gear()功能吗?我可以在保持scalability-factor原样的同时对其进行更多优化吗?提前致谢。如果我想把所有这些函数都放在C++asClass EngineClass Gearbox中,你能给我看一个原型吗?

4

2 回答 2

1

抛开优化不谈,您的 input_arr 有问题:

int input_arr[MILES] = {1,3,2,2,1,3,2,1,1,3,2,2,1,2,3}; //has 15 elements   

虽然以下循环需要 16:

for (i=0; i<MILES-1; i++) { //[edited] so i goes from 0 to 13
        v6 = ignition_phase(input_arr[i], input_arr[i+1]);  //otherwise, i goes to 14, +1 == 15 - 1 too big
        printf("%p\n", v6);
}

要么创建一个更大的数组,要么提前停止循环 1 增量。

关于这段代码:

struct package *engine_spin_at_gear(struct package *_init_cycle0, int countSession)
{
        while (countSession--) {
                shift_gear(_init_cycle0);  // }
                return deliver(base(_init_cycle0));
        }
        return NULL;
}  //move this one to after shift_gear(_init_cycle0); 

是否应该将结束的 while 循环 }移动到注释中指示的位置?(根据您和查理的观察)如果您将 return 语句保留在那里,您将永远不会超过第一个循环。

输出根据对代码的微小更改而更改:
更改为for (i=0; i<MILES; i++) {之后for (i=0; i<MILES-1; i++) {
在此处输入图像描述

改变后

while (countSession--) {
        shift_gear(_init_cycle0);
        return deliver(base(_init_cycle0));
}

至:

while (countSession--) {
        shift_gear(_init_cycle0);}
        return deliver(base(_init_cycle0));

// }

在此处输入图像描述

所以,似乎有一些影响,但我不确定如何解释这个输出。即这些变化意味着什么意义。

于 2013-10-18T23:09:50.983 回答
1

你提到扩展到更多的项目,这里有一些扩展到 100 的部分,

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct package_s
{
    // ... other members data ...
    struct package_s* next;
} package; //being lazy, I avoid typing struct everywhere...

#define HOWMANY (100)
package* v[HOWMANY];

#define MILES 15
int input_arr[MILES] = {1,3,2,2,1,3,2,1,1,3,2,2,1,2,3};

package*
journey(package* _current_frame, int _start, int _end)
{
    int rpm = (_end > _start) ? (_end-_start) : (_start-_end);
    if (rpm)
        return engine_spin_at_gear(_current_frame, rpm);
    else
        return v[0];
}

package*
ignition_phase(int _batteryS, int _chargedL)
{
    return journey(v[0], _batteryS, _chargedL);
}

这修复了 input_arr 末尾的寻址(也许你想回零?)

void
transmit_in_order(int*input_arr)
{
    package *v6;
    int i;

    for (i=0; i<MILES-2; i++) {
        v6 = ignition_phase(input_arr[i], input_arr[i+1]);
        printf("%p\n", v6);
    }
}

主要用于可配置的数量v[n]

int main()
{
    int ndx;
    for(ndx=0; ndx<HOWMANY; ++ndx)
    {
        v[ndx] = malloc(sizeof(package));
    }

    for(ndx=0; ndx<HOWMANY; ++ndx)
    {
        v[ndx]->next = v[(ndx+1)%HOWMANY];
        printf("v[%d]=%p\t", ndx, v[ndx]);
    }
    printf("\n", ndx, v[ndx]);

    transmit_in_order(input_arr);
    return 0;
}
于 2013-10-19T02:14:46.453 回答