| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 710 人关注过本帖
标题:程序有问题啊
取消只看楼主 加入收藏
心动音符
Rank: 1
等 级:禁止访问
威 望:1
帖 子:832
专家分:0
注 册:2005-9-15
收藏
 问题点数:0 回复次数:1 
程序有问题啊
有N个人坐成一圈,从S个人开始报数,当报到J的时候 删除这个J位置的人,一直删到最后剩一个时候停止,求出剩下的是哪个人。假设:人用数组表示a[N]={0,1,2,3,4,5,6,7,8,9};

下面是我的程序,但是有错误,我编的时候也比较混乱可以我觉得我的算法应该是对的,望大家帮我找出错误谢谢。斑竹也对我的程序评价一下啊
PS:最好 是按我的算法来做 如果算法有问题请指出不要用链表


#include <iostream>
using namespace std;
#define N 10;
void del(int q) 这个函数是删除J位置的人 q是指针 指向J
{ int *p=q;
while(*p!='/0') 判断是否到串尾
{*q=*(p+1);q++;p++;} 删除 J位置的人
*q='/0';
}
void fine(int a,int s,int j) 找出J所在的位置
{ int i=1; 定义一个记数变量
int *p=&a[s]; 从S位置开始
while(i<=j) 判断是否报到J
{if(*(p+i)=='/0') 判断是否到串尾
*(p+i)=a; 到串尾让它掉头继续报直到报到J
i++;
}
del(*(p+i)); 因为报到了J 所要调用删除函数删除J位置的人
}
int main()
{int a[N]={0,1,2,3,4,5,6,7,8,9},s=3,j=2;
while(N!=1)
{fine(*a,s,,j);
N--;}
return 0;
}

[此贴子已经被作者于2006-8-11 16:56:36编辑过]

搜索更多相关主题的帖子: 算法 void include color 
2006-08-11 13:21
心动音符
Rank: 1
等 级:禁止访问
威 望:1
帖 子:832
专家分:0
注 册:2005-9-15
收藏
得分:0 
大家来看看啊 再不看就沉了啊

2006-08-12 21:54
快速回复:程序有问题啊
数据加载中...
 
   



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

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