c语言实例 魔术师的猜牌术(1),C语言实例 魔术师的猜牌术(1)

博客解析了一个涉及数组操作和循环的编程问题,通过实例讲解如何根据特定序列来填充数组。文章指出,理解实现过程比直接获取答案更重要,并提供了简化版的程序代码,帮助读者更好地理解数数和跳数的逻辑。同时,文章强调了全局变量的初始化和条件判断在程序中的作用,有助于初学者掌握编程技巧。
摘要由CSDN通过智能技术生成

满意答案

02ae427d08e371d7e90d5b995e828d6d.png

u6jjltfs0v

2014.05.15

02ae427d08e371d7e90d5b995e828d6d.png

采纳率:43%    等级:12

已帮助:4849人

这个问题你想让别人一步一步帮你递推演示,要累死人的。不仅解释的人累,大段大段的无聊文字你看着都累。

很多程序题目最主要的是理解实现过程,只要过程理解了,程序自己也可以写出来。

我帮你点拨一下吧。

首先,你可以把答案打印出来,照着答案自己循环数一下,通过这个过程,把每个数字到底是怎么出来的搞明白。

数据如下:1 8 2 5 10 3 12 11 9 4 7 6 13

然后开始数:先是1;再数2个是2;再数3个是3;……;数到4要数5的时候,7(1)、6(2)、13(3)、1(跳掉)、8(4)、2(跳掉)、到了,填5;……

明白了吗?

程序中n就是刚才括号里数的东西,a[j]就是刚才数的7,6,13……(程序运行的时候这些不用跳掉的数字还没有赋值,都是0),现在应该能明白了吧。

整个do-while语句内实现的就是刚才数的过程,j碰到结尾就从头开始。j碰到需要跳掉的时候就j++,否则就j++;n++,直到n==i。

补充一些基础知识:

(1)全局变量int a[14];运行前全部是0。

(2)if(a[j]),0的话就是false,赋过值了就是true。

其实这个程序写得不是非常有条理(不过执行效率不错),初学者读起来有点困难。想方便阅读的话,可以让n从0开始。n++以后再判断n==i。我帮你写个可读性强点的程序吧,读完我的再读他的,应该方便很多。

#include<stdio.h>

int a[14]={0};//显式地赋0值

int main()

{

int i,n,j=1;

printf("The original order of cards is:");

for(i=1;i<=13;i++)

{

n=0;

while(n!=i){//换成do-while也一样

if(a[j]==0){//如果位置空,n就计数

n++;

if(n==i)//到了,赋值

a[j]=i;

}

j=j==13?1:j+1;//j一直计数

}

}

for(i=1;i<=13;i++)

printf("%d ",a[i]);

printf("\n");

}

00分享举报

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值