| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 348 人关注过本帖
标题:请问我下面的程序可行吗?如果不行,要怎么修改,谢谢各位啦!!
只看楼主 加入收藏
lxl1026
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2010-11-16
结帖率:0
收藏
 问题点数:0 回复次数:3 
请问我下面的程序可行吗?如果不行,要怎么修改,谢谢各位啦!!
13个人围成一圈从1开始报数凡报道3的倍数离开圈子,然后数下去直到剩下最后一个人止,最后输出留在圈子的人原来的位置是多少?
#include<stdio.h>
#define NULL 0
struct person
{int num;
struct person *next;
}a[13]={{1},{2},{3},{4},{5},{6},{7},{8},{9},{10},{11},{12},{13}};

void main()
{
    struct person *p,*head,*p1,*p2;
p1=head=a;


while((p1->num)%3!=NULL&&p1->next!=NULL)
 {p2=p1;p1=p1->next;
}

if((p1->num)%3==NULL)
{if(p1==head)
head=p1->next;
else
p2->next=p1->next;
}

printf("the remain number:\n");
p=head=a;
if(head!=NULL)
do
{printf("%d\n",p->num);
p=p->next;
}while(p!=NULL);
}
2010-11-18 14:38
南国利剑
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:29
帖 子:1165
专家分:3536
注 册:2010-4-12
收藏
得分:0 

是否可行,你应该问机器?
不是吗?

南国利剑
2010-11-18 17:52
freedgun
Rank: 5Rank: 5
等 级:职业侠客
帖 子:147
专家分:302
注 册:2010-11-11
收藏
得分:0 
运行可行   结果为 :1

有什么样的付出,就有什么样的收获!!
2010-11-18 20:41
cq7610
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:28
专家分:111
注 册:2010-11-17
收藏
得分:0 
我也来写着玩吧。阴天打孩子,闲着也是闲着。注意代码里没有释放链表节点的内存,偷个懒。:)

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

#define RENCOUNT 13

typedef struct REN{
    int place;
    struct REN * next;
}REN;

int main(void)
{   
    REN * newItem;
    REN * currItem;
    REN * tempItem;
    int j = 1;
    int i;
    int k = 13;

    currItem = malloc(sizeof * currItem);
    currItem->place = 13;
    currItem->next = NULL;
    tempItem = currItem;
   
    for(i = RENCOUNT - 1; i >= 1; i--){
        newItem = malloc(sizeof * newItem);
        newItem->place = i;
        newItem->next = currItem;
        currItem = newItem;
    }

    tempItem->next = currItem;

    while(k > 1){
            if(j % 3 == 0){
                tempItem->next = currItem->next;
                k--;
            }
            tempItem = currItem;
            currItem= currItem->next;
            j++;
    }
   
    printf("答案是:%d", currItem->place);
    return 0;
}
2010-11-18 23:03
快速回复:请问我下面的程序可行吗?如果不行,要怎么修改,谢谢各位啦!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.027853 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved