小程序(六) 随机数按计数输出问题

约瑟夫问题

 

输入一个由随机数组成的数列(数列中每个数均是大于0的整数,长度已知),和初始计数值m。从数列首位置开始计数,计数到m后,将数列该位置数值替换计数值m,并将数列该位置数值出列,然后从下一位置从新开始计数,直到数列所有数值出列为止。如果计数到达数列尾段,则返回数列首位置继续计数。请编程实现上述计数过程,同时输出数值出列的顺序

 

比如:输入的随机数列为:3,1,2,4,初始计数值m=7,从数列首位置开始计数(数值3所在位置)

第一轮计数出列数字为2,计数值更新m=2,出列后数列为3,1,4,从数值4所在位置从新开始计数

第二轮计数出列数字为3,计数值更新m=3,出列后数列为1,4,从数值1所在位置开始计数

第三轮计数出列数字为1,计数值更新m=1,出列后数列为4,从数值4所在位置开始计数

最后一轮计数出列数字为4,计数过程完成。

输出数值出列顺序为:2,3,1,4。

 

要求实现函数:

void array_iterate(int len, int input_array[], int m, int output_array[])

 

【输入】 int len:输入数列的长度;

int intput_array[]:输入的初始数列

int m:初始计数值

 

【输出】 int output_array[]:输出的数值出列顺序

 

【返回】 无

 

示例:

输入:int input_array[] = {3,1,2,4},int len = 4, m=7

输出:output_array[] = {2,3,1,4}


第一种方法:不用链表,用一般方法,代码简短,但不太容易想。


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

 void array_iterate(int len, int input_array[], int m, int output_array[])
 {
     int startIndex = 0; // 下一次开始计数的下标
     int chooseIndex = 0; // 选中的下标
     int outputIndex = 0; // 输出数组的下标
     while(len > 0)
     {    
         startIndex = chooseIndex;
         chooseIndex = (startIndex + (m - 1) % len) % len;
         m = input_array[chooseIndex];
         output_array[outputIndex++] = m;
         // 数组左移
         for(int i = chooseIndex; i <= len  - 2; ++i)
         {
             input_array[i] = input_array[i + 1];
         }
         -- len;
     }
 }

 int main()
 {
     int input_array[] = {3,1,2,4,7,9,13};
     int output_array[7];
     int len = 7, m=7;
     array_iterate(len, input_array, m, output_array);
     //output(output_array, len);
	// int *q = output_array;
	 for(int i=0;i<7;i++)
		 printf("%d ",output_array[i]);
     getchar();
	 return 0 ;
 }


第2种方法,用循环链表,直观,方便。

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


typedef struct node{
	int data;
	struct node *next;
}node,*Linklist;


void create( Linklist &L,int *input_array,int len )
{
  Linklist p,s;
  int i;
  //int len = sizeof(input_array)/sizeof(int);
  //int len=4;
  p = L;
  p->data = input_array[0];
  for(i=1;i<len;i++)
  {
	  s = (Linklist)malloc(sizeof(node));
	  s->data = input_array[i];
	  p->next = s;
	  p = s;
  }
  p->next = L;
}


void array_iterate( int len, int input_array[], int m, int output_array[] )
{
  Linklist L,p,q,s;
  int i,j;
  j=0;
  L = (Linklist)malloc(sizeof(node));
  create(L,input_array,len);
  p = L;
  while( p != p->next )
  {
      for(i=1;i<m;i++)
	  { 
	    s = p;
        p = p->next;
	  }
      output_array[j++] = p->data;
      m = p->data;
	  q = p;
	  s->next = p->next;
	  p = p->next;
      free(q);
  }
  output_array[j++] = p->data;
}



int main()
{
	int input_array[]={3,1,2,4};
	int len=4;
	int m=2;
	int output_array[4];
	array_iterate(len,  input_array, m,output_array);
	for(int i=0;i<4;i++)
	    printf("%d\n",output_array[i]);
	return 0;
}




如果作为函数的参数是没法求的,> 但这样是可以的:

> > #define LENGTH(s) (sizeof(s) / sizeof(int))

> > int s[12];

> int length = LENGTH(s);

这样的方法只能用于数组变量的数组名,对于指向数组的指针,以及作为参数的数组名都是没有效果的,上面已经有人解释了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
108题中有部分题目重合,因此么有收录在压缩文件中。 华为机试 ├─001 字符串最后一个单词长度 │ └─Source ├─002 计算字符个数 │ └─Source ├─003 明明的随机数 │ └─Source ├─004 字符串分隔 │ └─Source ├─005 进制转换 │ └─Source ├─006 质数因子 │ └─Source ├─007 取近似值 │ └─Source ├─008 合并表记录 │ └─Source ├─009 提取不重复的整数 │ └─Source ├─010 字符个数统计 │ └─Source ├─011 数字颠倒 │ └─Source ├─012 字符串反转 │ └─Source ├─013 句子逆序 │ └─Source ├─014 字典序排序 │ └─Source ├─015 求int型正整数在内存中存储是1的个数 │ └─Source ├─016 购物单 │ ├─Debug │ ├─Source │ │ └─Debug │ ├─Source - 时间优先 │ │ └─Debug │ └─Source - 空间优先 │ ├─Debug │ └─Release ├─017 坐标移动 ├─018 识别IP地址分类统计 │ └─Source │ └─Debug ├─019 错误记录 ├─020 密码验证合格程序 ├─021 密码破解 ├─023 删除字符串中出现次数最少字符 │ └─Source │ └─Debug ├─024 合唱队 │ └─Source │ ├─Debug │ └─Release ├─025 数据分类处理 │ └─Source │ └─Debug ├─026 查找兄弟单词 │ └─Source │ └─Debug ├─027 素数伴侣 │ └─Source │ └─Debug ├─028 字符串合并处理 │ └─Source │ └─Debug ├─030 密码截取(查找最长回文字符串) ├─031 蛇形矩阵 │ └─Source │ └─Debug ├─033 判断IP是否属于同一子网 │ └─Source │ └─Debug ├─034 称砝码 │ └─Source │ └─Debug ├─035 学英语 │ └─Source │ └─Debug ├─036 迷宫问题 │ └─Source │ └─Debug ├─037 数独问题 │ └─Debug ├─038 名字漂亮度 │ └─Source │ └─Debug ├─039 字符串截取 │ └─Source │ └─Debug ├─040 单链表删除数据 │ └─Source │ └─Debug ├─041 多线程 │ └─Source │ ├─Backup │ ├─Debug │ │ └─041.tlog │ └─Release │ └─041.tlog ├─042 表达式计算 │ └─Source │ └─Debug ├─043 计算字符串距离 │ └─Source │ └─Debug ├─044 杨辉三角形变形 ├─046 挑7 ├─047 完全数 │ └─Debug ├─048 高精度加法 ├─049 输出n个数中最小的k个 │ └─Debug ├─050 找出字符串只出现一次的字符 │ └─Debug ├─051 组成一个偶数最接近的2个质数 │ └─Debug ├─052 M个苹果放入N个盘子 ├─053 查找整数二进制中1的个数 ├─054 DNA子串 ├─055 MP3光标位置 │ └─Source │ └─Debug ├─056 查找2个字符串最大相同子串 │ └─Debug ├─057 配置文件恢复 │ └─Source │ └─Debug ├─058 24点计算 │ └─Debug ├─059 成绩排序 ├─060 矩阵相乘 ├─061 矩阵乘法次数计算 ├─062 字符串通配符 │ └─Debug ├─066 命令行解析 │ └─Source │ └─Debug ├─067 最大相同子串长度 │ └─Debug ├─068 火车编号进站 │ └─Debug ├─072 数组合并 ├─074 埃及分数 │ └─Source │ └─Debug ├─076 密码截取 │ └─Source ├─077 求最大连续bit数 ├─078 密码强度 ├─079 扑克牌大小 │ └─Source │ └─Debug ├─081 合法IP ├─082 棋盘格子走法 ├─083 在字符串中找出连续最长数字串 ├─084 int数组分组,两组和相等 │ └─Source │ └─Debug ├─086 人民币转换 │ └─Source │ └─Debug ├─087 表示数字 ├─090 自动售货系统 │ └─Source │ └─Debug └─091 24点输出 └─Debug
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值