Bailian2888 字符串中的数字【字符串】

     字符串中的数字

总时间限制: 
1000ms  
内存限制: 
65536kB
描述
输入一个字符串,长度不超过20,字符串中包含数字和非数字字符,将其中是数字的字符提取出来,对它们进行从小到大排序,非数字字符则忽略不计。
输入
若干行字符串
输出
每一个字符串中所有数字的升序排序。每个数字占四个字符位置。使用cout<< setw(4)<< num;
处理完一行字符串换行一次。使用cout<< endl;
样例输入
31W 7Q9 2D2
4d t51 X9P
样例输出
   1   2   2   3   7   9
   1   4   5   9
提示
1.由于有多组测试数据,要求使用while循环读取输入。如下:
while(cin.getline(str,21))
{
//你的代码
}
2.setw(4)函数需要#include < iomanip >

问题链接Bailian2888 字符串中的数字

问题分析:一是要求把数字找出来,及(0 到 9)较为简单,然后将这些数字排序输出,因为题中已要求宽度为四输出,所以就剩怎么实现了,我想的是借用数组,首先先循环读入,便输入边处理,将数字挑出来放到数组中去,然后在进行排序,冒泡,快速等,(冒泡记住是从小到大排序)

程序说明:排序和输出格式宽度为4是关键。

题记:按照提示来

AC 的程序
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define N 20
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
char s[N + 1], t[N+1];
int main() 
{
    int i , n;
    i = 0;
    n = 0;
    while(gets(t))
    {
    	n = 0;
    	for(i = 0;i<strlen(t);i++)
	{
    	if(t[i]>= '0'&& t[i] <= '9')
    		s[n++] = t[i];
	}
	
		char t;
		int a,j;
		a = 0;
		j = 0;
		for(a = 0;a < n;a++)
			for(j = 0;j <= a;j++)
				{
					if(s[a] < s[j])
					{
						t = s[a];
						s[a] = s[j];
						s[j] = t;
				        }
				}
		for(j = 0; j < n; ++j)
			printf("%4c", s[j]);
			printf("\n");
	}
	return 0;
}
/*while循环用gets()可以实现行处理,知道遇到终止符,排序算法自己在搞一搞*/ 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
openjudge约瑟夫问题是一个数学应用问题。问题的描述是:有n个人(以编号1,2,3...n分别表示)围坐在一张圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。最后剩下的那个人就是猴王的编号。 这个问题在openjudge的输入格式是每行是用空格分开的两个整数,第一个是n, 第二个是m (0 < m,n <= 300)。最后一行是0 0作为输入的结束标志。 要解决openjudge约瑟夫问题,我们需要编写一个程序来接收输入的n和m值,并按照约瑟夫问题的规则计算出最后剩下的猴王的编号。具体的解题算法可以使用循环队列或者递归的方式来实现,具体实现的代码可以根据具体的编程语言来完成。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [openjudge 约瑟夫环问题](https://blog.csdn.net/sdz20172133/article/details/88351098)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [bailian.openjudge 2746:约瑟夫问题](https://blog.csdn.net/smartzxf/article/details/100829938)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值