当前位置:   article > 正文

在字符串中找出最大的字符并移到首位_【问题描述】在字符串str中找出最大的字符放在第一个位置上,并将该字符前的原字符

【问题描述】在字符串str中找出最大的字符放在第一个位置上,并将该字符前的原字符

在字符串str中找出最大的字符并放在第一个位置上,并将该字符前的原字符往后顺序移动。

#include <stdio.h>
int main(){
	char str[80],max,*p,*q;
	p=str;
	
	gets(p);
	max=*(p++);
	
	while(*p != '\0'){
		if(max<*p){ 
			max=*p; 		//max存放最大值 
			q=p;			//q存放最大值地址 
		}
		p++;
	}
	p=q;
	while( p>&str[0]) { 	//从最大位置开始向前逆序遍历,每次将前一个字符后移一位。 
		*p=*(p-1);p--;
	}
	*p=max;
	
	puts(p);
	
	return 0;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

https://blog.csdn.net/duzzle2016/article/details/82879075

1,数组是一块内存连续的数据。
2,指针是一个指向内存空间的变量。

对于数组来说,数组的首地址,也可以用指针来表示操作,如:
int a[10];
int *p,n;
p = a;
对第一个元素取值,可以用几种方法:
n =a[0];
n = *p;
n = p[0];
n = *(p+0) ;

3,不同的地方是数组是由编译器分配的空间,变量名是不能再赋值的;而指针是可以重复赋值的(除定义为const)
如:
p = a; //正确
a = p; //错误

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/310071
推荐阅读
相关标签
  

闽ICP备14008679号