标题:数字翻牌算法---求助+讨论
只看楼主
dill131
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2006-9-8
 问题点数:0 回复次数:2 
数字翻牌算法---求助+讨论

编号为1-52张牌,正面向上,从第2张开始,以2为基数,是2的倍数的牌翻一次,直到最后一张牌;然后,从第3张开始,以3为基数,是3的倍数的牌翻一次,直到最后一张牌;然后…从第4张开始,以4为基数,是4的倍数的牌翻一次,直到最后一张牌;...再依次5的倍数的牌翻一次,6的,7的,直到以52为基数的翻过,输出此时正面向上的牌。输入数据:纸牌编号; 如上规则所述,输出最后正面向上的纸牌编号。

用线性表的存储来实现一个C++算法,谁有比较简单的算法,互相交流一下

以下是个例子,好象不对
#include<iostream>

using namespace std;

int main(int agc,char* agm[])
{
bool card[6];
int card_index = 0;
for(;card_index < 6;card_index++)
card[card_index] = true;
for(card_index = 2;card_index < 6;card_index++)
{
for(int times = 2;card_index*times < 6;times++)
{
card[card_index*times]= (card[card_index*times]==true)? false:true;
}
}
for(card_index = 1;card_index < 6;card_index++)
if(card[card_index] == true)
cout<<card_index<<endl;
return 1;
}

搜索更多相关主题的帖子: 翻牌 算法 数字 
2006-09-08 08:33
radcat
Rank: 3Rank: 3
等 级:论坛游民
威 望:8
帖 子:306
专家分:45
注 册:2006-9-12
得分:0 

#include <iostream.h>

void main()
{
int sum[52];
static int j,k=2;;
int i;
for(i=0;i<52;i++)
{
sum[i]=0;
}
while(k<=52)
{

for(j=k;j<52;j=j*k)
{
sum[j]=1;
cout<<j;
}
k++;
}
}


2006-09-13 15:13
Bekky
Rank: 3Rank: 3
等 级:新手上路
威 望:7
帖 子:354
专家分:0
注 册:2006-5-29
得分:0 
struct card
{
int mindex;
bool bState;//TRUE表示正面,FALSE表示反面
};

function()
{
int counter=1;
card myCard[52];
//初始化
for(int i =0;i<52;i++)
{
myCard[i].mindex = i+1;
myCard[i].bState = TRUE;
}

//挑选符合条件的牌
while(counter <= 52)
{
if(counter == 1)
counter += 1;
for(int i = counter;i< 52;i++)
if(myCard[i].mindex % counter == 0)
myCard[i].bState = FALSE;
counter ++;
}

//检索这副牌,看看哪些是TRUE,即没有翻过去的牌,正面向上的牌
for(int i =0;i < 52;i++)
if(myCard[i].bState)
cout << myCard[i].mindex<<endl;//输出正面的牌号
}

main()
{
function();
}

[此贴子已经被作者于2006-9-14 16:44:34编辑过]


我的编译环境为WinXp + VC 6.0 http://blog..cn/yobo
2006-09-13 16:30



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-88762-1-1.html




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

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