这道题没做过不会啊兄弟们,帮帮我(c语言)
(用c语言)从键盘输入一个字符串(不含空格,长度小于1000),字符串里只包含大写字母,小写字母和0-9数字字符,现在需要将其中的大写字母、0-9数字字符和小写字符按照升序排序后输出。输出顺序为:排序后的大写字母,排序后
的0-9数字,排序后的小写字母。
输入数据有多组!
(注意:提取的字符组成新的字符串后末尾要加'\0')
样例输入:
aaadc3429AFD
123ABCabc2
样例输出:
ADF2349aaacd
ABC1223abc 本帖最后由 jackz007 于 2022-10-20 21:42 编辑
#include <stdio.h>
void swap(char * a , char * b)
{
char t ;
t = * a ; * a = * b ; * b = t ;
}
int main(void)
{
char ch , s ;
int i , j , k , m , n ;
for(n = 0 , m = 1 ; m ; n ++) {
gets(s) ;
for(m = 0 ; s ; m ++) {
if(s >= 'a' && s <= 'z') s += 4 ;
else if(s >= '0' && s <= '9') s += 43 ;
}
for(i = 0 ; i < m - 1 ; i ++) for(j = i + 1 ; j < m ; j ++) if(s > s) swap(& s , & s) ;
for(i = 0 ; i < m ; i ++) {
if(s >= 'a' + 4) s -= 4 ;
else if(s > 'Z' && s < 'a' + 4) s -= 43 ;
}
}
for(i = 0 ; i < n ; i ++) printf("%s\n" , s) ;
}
编译、运行实况:
D:\\C>g++ -o x x.c
aaadc3429AFD
123ABCabc2
ADF2349aaacd
ABC1223abc
D:\\C> 本帖最后由 jhq999 于 2022-10-20 11:08 编辑
intmain( )
{
char str={0},ch=0;
int len=0;
while((ch=getchar())!='\n')
{
if(ch>='A'&&ch<='Z')
{
str+=1;
str=ch;
}
else if(ch>='0'&&ch<='9')
{
str+=1;
str=ch;
}
else
{
str+=1;
str=ch;
}
len+=1;
}
char s;
for(int i=0,k=0;i<62;i+=1)
{
for(int j=0;j<str;j+=1)
{
s=str;
}
}
s='\0';
printf("%s",s);
return 0;
}
aaadc3429AFD
ADF2349aaacd
Process returned 0 (0x0) execution time : 1.693 s
Press any key to continue.
我就很烦这种题目
输入输出没问题就行了,你还要求我怎么写程序么
需要把输出数据转为字符串然后一并输出吗?
#include <stdio.h>
int output_line(void) {
size_t chars = {0};
while(1) {
int ch = getchar();
if(ch == EOF) return EOF;
if(ch == '\n') break;
++chars;
}
for(size_t i = 'A'; i <= 'Z'; ++i) {
while(chars--) putchar(i);
}
for(size_t i = '0'; i <= '9'; ++i) {
while(chars--) putchar(i);
}
for(size_t i = 'a'; i <= 'z'; ++i) {
while(chars--) putchar(i);
}
putchar('\n');
return 0;
}
int main(void) {
while(output_line() != EOF);
}
#include <stdio.h>
int output_line(void) {
size_t chars = {0};
size_t count = 0;
while(1) {
int ch = getchar();
if(ch == EOF) return EOF;
if(ch == '\n') break;
++chars; ++count;
}
char str; str = '\0';
char *p = str;
for(size_t i = 'A'; i <= 'Z'; ++i) {
while(chars--) *p++ = i;
}
for(size_t i = '0'; i <= '9'; ++i) {
while(chars--) *p++ = i;
}
for(size_t i = 'a'; i <= 'z'; ++i) {
while(chars--) *p++ = i;
}
printf("%s\n", str);
return 0;
}
int main(void) {
while(output_line() != EOF);
}
忘了加return 0; 了
$ cat main.c{,~}
#include <stdio.h>
int output_line(void) {
size_t chars = {0};
size_t count = 0;
while(1) {
int ch = getchar();
if(ch == EOF) return EOF;
if(ch == '\n') break;
++chars; ++count;
}
char str; str = '\0';
char *p = str;
for(size_t i = 'A'; i <= 'Z'; ++i) {
while(chars--) *p++ = i;
}
for(size_t i = '0'; i <= '9'; ++i) {
while(chars--) *p++ = i;
}
for(size_t i = 'a'; i <= 'z'; ++i) {
while(chars--) *p++ = i;
}
printf("%s\n", str);
return 0;
}
int main(void) {
while(output_line() != EOF);
return 0;
}
#include <stdio.h>
int output_line(void) {
size_t chars = {0};
while(1) {
int ch = getchar();
if(ch == EOF) return EOF;
if(ch == '\n') break;
++chars;
}
for(size_t i = 'A'; i <= 'Z'; ++i) {
while(chars--) putchar(i);
}
for(size_t i = '0'; i <= '9'; ++i) {
while(chars--) putchar(i);
}
for(size_t i = 'a'; i <= 'z'; ++i) {
while(chars--) putchar(i);
}
putchar('\n');
return 0;
}
int main(void) {
while(output_line() != EOF);
return 0;
}
$
jhq999 发表于 2022-10-20 11:04
膜拜大神{:10_281:} 人造人 发表于 2022-10-20 11:21
忘了加return 0; 了
膜拜大神{:10_281:} jackz007 发表于 2022-10-20 13:24
编译、运行实况:
自己功底浅,大神的代码看不太懂{:10_266:}我再琢磨琢磨,给大神点赞{:10_281:} ZZZZZZZZZZ
#include <stdio.h>
int main(void) {
char c;
int res = { 0 };
while ((c = getchar()) != '\n') res++;
for (int i = 'A'; i <= 'Z'; ++i) {
for (int j = 0; j < res; ++j) printf("%c", i);
res = 0;
}
for (int i = 0; i < 256; ++i) {
for (int j = 0; j < res; ++j) printf("%c", i);
}
return 0;
} 竹逸 发表于 2022-10-20 21:16
自己功底浅,大神的代码看不太懂我再琢磨琢磨,给大神点赞
这题比较麻烦的是要求最后的排序结果要把数字放到大小写字母之间,我们知道,数字的 ASCII 编码比大小写字符都要小,如果按正常的 ASCII 码大小排序,那么,数字只能数字只能出现在字符串的两边,而不可能是中间,针对这个问题,排序前,人为修改数字的 ASCII 编码,使其位于大小写字母之间,但是,在 'Z' 和 'a' 之间只有 6 个字符的位置,无法容纳 10 个数字字符,于是,又把小写字符的编码整体向后移动了 4 个字符位置,这样,就形成了大写字母在前,数字在中,小写字母在后的格局,这样操作过后,直接排序操作,然后,逆序恢复字符串中各个字符的原始编码,事情就成了。 jackz007 发表于 2022-10-20 21:38
这题比较麻烦的是要求最后的排序结果要把数字放到大小写字母之间,我们知道,数字的 ASCII 编码 ...
看着你说的这个思路完全跟不上看你的代码.请教一下,这种双for使用如何练成的,话说到现在我还是最怕这种烧脑布局.有什么学习好它的决窍吗.谢谢. howzyao 发表于 2022-10-20 21:46
看着你说的这个思路完全跟不上看你的代码.请教一下,这种双for使用如何练成的,话说到现在我还是最怕这种烧 ...
把复杂的问题简单化,像我那样
如果不能简单化它,那就把它挂起,直到未来的自己找到了简单化它的方法,然后完成它
howzyao 发表于 2022-10-20 21:46
看着你说的这个思路完全跟不上看你的代码.请教一下,这种双for使用如何练成的,话说到现在我还是最怕这种烧 ...
多层循环只为了执行一条语句,写到同一行节省空间。
这样很难理解吗? 傻眼貓咪 发表于 2022-10-20 21:22
ZZZZZZZZZZ
你是牛A和牛C之间的人{:5_106:} jackz007 发表于 2022-10-20 21:59
多层循环只为了执行一条语句,写到同一行节省空间。
这样很难理解吗?
aaadc3429AFD
123ABCabc2
样例输出:
ADF2349aaacd
ABC1223abc
这个要求,我觉得要把A到A++直到Z这段,
放在首位
0-9放在二位
a....z放三位,
凡是满足阶段一的,放方法一中处理。方法二的放二,三放三。
然后三段相加。
这是我的思路。还没有具体代码,不过看了二位学长的代码后,我确实发觉自己太欠缺了,只能将心里想的说出来,不知道有没有可能实现。 傻眼貓咪 发表于 2022-10-20 21:22
ZZZZZZZZZZ
我觉得元素的个数定为123可能更好{:5_91:} 我基本上只会笨办法:
准备3个数组。用来放字符。
再弄一个数组长度是整个ascii的长度。
比如65时,有字符,就存之没有,就略过。
howzyao 发表于 2022-10-20 22:11
aaadc3429AFD
123ABCabc2
样例输出:
有想法就把它实现出来。
你也可以先无差别排序,然后,把数字段整体挪到大小写字符段之间。 jackz007 发表于 2022-10-20 21:38
这题比较麻烦的是要求最后的排序结果要把数字放到大小写字母之间,我们知道,数字的 ASCII 编码 ...
怪不得我看不懂你那个+4是什么意思,原来是这样啊{:5_106:} 竹逸 发表于 2022-10-20 21:16
自己功底浅,大神的代码看不太懂我再琢磨琢磨,给大神点赞
不是吧,没看懂?统计所有输入字符出现的次数,然后遍历 大写字母 , 数字,小写字母 ,并把字符出现次数大于0的字符,按'A'- 'Z'的顺序输出而且每个大写字符输出的个数为统计时的个数 。按'0'- '9'的顺序输出而且每个数字字符输出的个数为统计时的个数 ,按'a'- 'z'的顺序输出而且每个小写字符输出的个数为统计时的个数
页:
[1]
2