㈠ 用c语言指针编程
有点麻烦,试试~~
最近考试有点忙,~
还未通过编译,你自己看着改改,我会尽快再发给你的。~~
1、首先格式化输入到栈,形式为:(字母开始,字母结束,空格分开不同单词,空格不能连续)。
2、构建子栈,步骤:由母栈经格式化(取每个单词后半部到子栈)。
3、排序。
4、输出。
子栈元素首行格式为(堆栈元素 + 指向一数据结构的指针)
#include<ctype.h>
#include<stdio.h>
#define STACK_INT_SIZE 100 //存储空间初始分配量
#define STACKINCREMENT 10 //存储空间分配增量
#define OK 0
typedef struct C_Node{
char elem;
struct C_Node *next;
}C_Node;
typedef struct C_Stack{
char C_elem;
char *base;
char *top;
C_Node *C_next;
}C_Stack;
typedef struct{
char *base;
char *top;
int stacksize;
}SqStack;
Status InitStack (SqStack &S)
{ S.base=(ElemType*)malloc(STACK_INIT_SIZE*sizeof(ElemType));
if (!S.base) exit (OVERFLOW); //存储分配失败
S.top = S.base;
S.stacksize = STACK_INIT_SIZE;
return OK;
}
Status Push (SqStack &S, char e) {
if (S.top - S.base >= S.stacksize) {//栈满,追加存储空间
S.base=(ElemType *)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof (ElemType));
if (!S.base) exit (OVERFLOW); //存储分配失败
S.top = S.base + S.stacksize;
S.stacksize += STACKINCREMENT;
}
*S.top++ = e;
return OK;
}
format_input()
{int Finish=0,flag;
char ch;
while(!Finish)
{flag=0;
scanf("%c",&ch);
if(' '==ch)
else if(isalpha(ch)){
if(0==flag)
else
}
else
}
}
Creat_C_Stack()
{指向 M_Stack 内元素的指针p(用于指向一个单词的最后字母),q(指向p的前方第一个空格元素);
指向 C_Stack 首行元素的指针C_i(),及随后元素的C_i_j(insert_place);
q=M_Stack.top;
p=M_Stack.top;
i=0;
q=top;
p=top-1;
num=0;
while(1)
for(;q.elem!=' ';)
q--;
i=(p-q-1)/2;
Insert_P=C_Stack[num];
Insert_P.elem=p.elem;
p--;
for(j=0;j<i;j--)
Insert_P.next=Insert_P.next;
Insert_P.elem=p.elem;
p--;
if(q==M_Stack) return;
}
Sort()
{C_Stack C_p=C_Stack[j],C_q=C_Stack[j+1],C_Temp;
for(C_p.next!=NULL&&C_q.next!=NULL)
{if(C_p.elem!=C_q.elem){
if(C_p.elem>C_q.elem){
C_temp=C_p;C_q=C_p;C_p=C_temp;
}
else
}
}
}
output()
{for(i=0;i<C_num;i++){
q=C_Stack[i];printf("%c",q.elem);
for(q.next!=NULL){
q=q.next;
printf("%c",q.elem);
}
}
}
#include<stdio.h>
void main()
{printf("只有空格和字母为有效字符,\n");
printf("其他字符将使输入结束。\n");
format_input();
Creat_C_Stack();
Sort();
Output();
}
㈡ 用指针完成c语言程序
int num[10];
void minToFirst()
{
int k,i,min;
int *p;
p = num;
min=*p;
k=0;
for (i=0;i<10;i++)
{
if(min>*(p+i))
{
min=*(p+i);
k=i;
}
}
*(p+k)=*p;
*p=min;
}
void maxToLast()
{
int k,i,max;
int *p;
max=*p;
k=0;
for (i=0;i<10;i++)
{
if(max<*(p+i))
{
max = *(p+i);
k=i;
}
}
*(p+k)=*(p+9);
*(p+9)=max;
}
main()
{
int i;
int *p;
printf("please input 10 NUM:\n");
for (i=0;i<10;i++)
{
scanf("%d",&num[i]);
}
p = num;
minToFirst();
maxToLast();
printf("output:\n");
for (i=0;i<10;i++)
{
printf("%d ",*p++);
}
getch();
}
㈢ c语言中,运用指针,从键盘输入10个整数,求出其中最小值
C语言程序如下:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
void input(int* p) {
for (int i = 0; i < 10; ++i, ++p) {
printf("请输入第%d个数的值 ", i + 1);
scanf("%d", p);
}
}
void print(int* p) {
for (int i = 0; i < 10; ++i, ++p) {
printf("%d ", *p);
}
printf(" ");
}
void fun(int* q) {
int* p = q;
int* minp = p;
int* maxp = p;
int temp;
for (int i = 1; i < 10; ++i, ++p) {
if (*maxp < *p) {
maxp = p;
}
if (*minp > *p) {
minp = p;
}
}
temp = *maxp;
*maxp = *p;
*p = temp;
temp = *minp;
*minp = *q;
*q = temp;
}
void main() {
int arr[10];
int* p = arr;
input(p);
print(p);
fun(p);
print("最小值为",p[0]);
system("pause");
}
(3)用指针输入c语言程序扩展阅读:
程序思路:
(指针方法处理)输入十个整数, 将其中最小的数与第一个数对换,把最大的数与最后一个数对换,因此便可得到最小值为指针的第一个元素。
将程序分为三部分:输入、比较、输出,分别对应一个函数
1、输入十个数;
2、进行处理;
3、 输出最小值。
㈣ c语言用指针完成字符串的输入和逆序输出,请问这个程序有啥问题
输出用 %c 格式 printf("%c",*p); 依次打印 一个一个 字符。
输入可用 gets(a); 读取一行字符串,这样 字符串中 允许有 空格。a 是数组首地址。
若写成 p=a; gets(p); fun(a); 也可以。
程序:
#include<stdio.h>
#include<stdlib.h>
void fun(char *p){
char *p0;
p0=p;
while(*p != '\0')p++;
for(;p>=p0;p--){
printf("%c",*p);
}
}
int main()
{
char a[100],*p;
gets(a); fun(a);
return 0;
}
㈤ 求一C语言程序 用指针的方法 从键盘上输入月份数字对应的输出表示的英文 自编函数
void main
{
int i=0;//循环用的
int scan=0, *s=&scan;
char yuefen[][10]={"one","two"," 忘了3的单词 "};//自已把英文写上。
char danci[10];//存放单词。
printf("请输入月份");
scanf("%d",s);
switch(*s)
{
case 1: for(i=0;i<10;i++)
danci[i]=yuefen[0][i];//数组都是从0开始,想从1开始,可以声明成[11]的。[0]不要
break;//对 switch一定要在每个case后加个break;不然会一直执行下去。
case 2: for(i=0;i<10;i++)
danci[i]=yuefen[1][i];
break;
懂了吧,就这样下去直到12
case 12: for(i=0;i<10;i++)
danci[i]=yuefen[11][i];//11是数组的第十二行,因为数组从0开始。
}
printf("%s",danci);
}
㈥ C语言:用指针来输入数据.
p是指针,因为开始定义的时候 *p=arr,就是表示p指向数组arr的首地址
scanf("%d",p); 于是就表示arr地址输入当前值。
等效于 scanf("%d",arr)
如果你开始没有把p指向某个地址,那肯定会出错的
㈦ C语言指针程序
#include<stdio.h>
#include<string.h>
char
*fun(char
*s,char
*t)//函数功能是在字符串S中找字符串T
{
char
*p,*r,*a;
a=NULL;//是一个标志,开始没查找到
//开始s=&s[0]
while(*s)//从S
的第一个字符开始查找,直到遇到'\0'
{
p=s;
r=t;
while(*r)//从T
的第一个字符开始查找,直到遇到'\0'
if(*r==*p)//如果在S字符串中找到了第一个
T字符串的T[0],
{
r++;//在比较T[1]
t[2]....
p++;//同上
}
else
break;
if
(*r=='\0')
a=s;//表明查找到了
s++;
}
return
a;//返回NULL没到到,否则找到了
}
main()
{
char
s[100],t[100],*p;
printf("\n
please
enter
string
S:");
scanf("%s",&s);
printf("\n
please
enter
string
T:");
scanf("%s",&t);
p=fun(s,t);
if(p)//真,为找到了
printf("\n
the
result
is
:%s\n",p);
else
printf("\n
not
found!\n");
}
㈧ 用指针编写C程序
好吧,我来帮你:
#include <stdio.h>
#include <string.h>
/*n个数排序*/
void sort(int a[],int n)
{
int *q,*qr;
int k=n;
while(k>1)
{
q=a;
qr=a+1;
while(q<a+k-1)
{
if(*q>*qr){int t=*q;*q=*qr;*qr=t;}
q++;
qr++;
}
k--;
}
}
void SortStr(char *a[],int n)
{
char **q,**qr;
int k=n;
while(k>1)
{
q=&a[0];
qr=q+1;
while(q<a+k-1)
{
if(strcmp(*q,*qr)>0){char *t=*q;*q=*qr;*qr=t;}
q++;
qr++;
}
k--;
}
}
int main( )
{
int a[]={4,2,7,1, 9};
char *b[5]={"bcde","abcd","abc","bcd","bcf"};
int i;
sort(a,5);
SortStr(&b[0],5);
for(i=0;i<5;i++)
printf("%4d",a[i]);
printf("\n");
for(i=0;i<5;i++)
printf("%-12s\n",b[i]);
return 0;
}
完整答案.快给分吧.你只要把5改成你要的数就可以了,如10.看起来好像字符串与整数有区别,其实在算法了相差并不大.
㈨ 用指针编写c程序
//实在是不想写了,写了半天,怎么发现还有这么多要写。这个先实现了拍名次。剩下的,你自己搞吧。
#include <stdio.h>
#include <string.h>
#define MAX 3 //此处测试使用3,应用时请改为30
#define NAMELEN 10 //名字长度
char name[MAX][NAMELEN];
int sn[MAX];
int MT[MAX];
int EN[MAX];
int PH[MAX];
int pos = 0; //是否输入满30个学生再停止输入,是否需设置输入停止符,并未做详细说明,暂将此定做全局变量,待以后更改使用。
void Sort();
void main()
{
char mode;
char keyword;
int temp;
char tname[10];
int i;
while(1)
{
printf("成绩录入(I)\n成绩排序(S)\n成绩查找(R)\n退出(Q)\n");
fflush(stdin);
scanf("%c", &mode);
if(mode == 'Q')
break;
switch(mode)
{
case 'I':
if(pos == MAX)
{
printf("Table is full. No more item is permitted!\n");
break;
}
while(pos != MAX)
{
printf("输入学生姓名:");
scanf("%s", name[pos]);
printf("输入学生编号:");
scanf("%d", &sn[pos]);
printf("输入数学成绩:");
scanf("%d", &MT[pos]);
printf("输入英语成绩:");
scanf("%d", &EN[pos]);
printf("输入体育成绩:");
scanf("%d", &PH[pos]);
printf("——————————————\n");
pos++;
}
break;
case 'S':
if(pos == 0)
{
printf("No student is in the table!\n");
break;
}
Sort();
printf("————————名次表————————————\n");
printf("姓名 学号 数学 英语 体育 总分 平均分\n");
for(i = 0; i < MAX; i++)
{
printf("%-8s%-8d%-6d%-6d%-6d%-6d%-6d\n", name[i], sn[i], MT[i], EN[i], PH[i], MT[i] + EN[i] + PH[i], (MT[i] + EN[i] + PH[i])/3);
}
break;
case 'R':
printf("请输入查询内容\n单个学生成绩查询(S)\n物理不及格情况(P)\n英语成绩平均分以上的学生(E)\n数学成绩各分数段人数统计(M)\n返回请按其它键\n");
fflush(stdin);
scanf("%c", &keyword);
switch(keyword)
{
case 'S':
break;
case 'P':
break;
case 'E':
break;
case 'M':
break;
default:
;
}
fflush(stdin);
scanf("%c", &keyword);
break;
}
}
}
void Sort()
{
int i, j, tem;
char t[NAMELEN];
for(i = 0; i < MAX; i++)
{
for(j = i; j < MAX; j++)
{
if(MT[i] + EN[i] + PH[i] < MT[j] + EN[j] + PH[j])
{
tem = MT[i];
MT[i] = MT[j];
MT[j] = tem;
tem = EN[i];
EN[i] = EN[j];
EN[j] = tem;
tem = PH[i];
PH[i] = PH[j];
PH[j] = tem;
tem = sn[i];
sn[i] = sn[j];
sn[j] = tem;
strcpy(t, name[i]);
strcpy(name[i], name[j]);
strcpy(name[j], t);
}
}
}
}
㈩ c语言使用指针,编写程序,从键盘r输入一个字符串,并统计各字母出现的次数(不区分大小写)。
摘要 是这样的#include