Thursday, March 11, 2010

a question about stack

in class we learned how S.pop() delete data in stack. My question is that whether we should delete data in reverse order?

S.push(Student("Fardad", "oop344", 56));

S.push(Student("John", "int322", 100));
S.push(Student("Jack", "int422", 90));
S.pop();
S.pop();
while(!S.IsEmpty()){
cout< }
Student StdStack::pop(){
Student ret = top->data;
Node* ToDel = top;
top = top->next;
delete ToDel;
return ret;
}
the output is Fardad, oop344: 56

i read some material in btp300
Element pop() {
Element data;
if (head) {
Node* p = head;
data = head->data;
head = head->next;
delete p;
}
return data;
}

Stack s;

// Push Data Onto Stack
s.push(3);
s.push(5);
s.push(9);
s.push(8);

// Remove first Node
s.pop();

// Pop Data Off Stack
while (!s.empty())
cout << s.pop().out() << ' ';
cout << endl;

the output is 9 5 3

could any one explain the difference between this two example why the pop() are different?

Monday, February 22, 2010

need help for tab_key

i find that when you insert '\t' in a string. it inserts 4 ' ' forward. But we write the bio library we can not control cursor to pass '\t' character.So can anyone teach me how to move cursor to pass '\t'?

Sunday, February 14, 2010

reiview for pointer and pointer to function

different type of pointer.
a) int a; // An integer
  b) int *a; // A pointer to an integer
  c) int **a; // A pointer to a pointer to an integer
  d) int a[10]; // An array of 10 integers
  e) int *a[10]; // An array of 10 pointers to integers
  f) int (*a)[10]; // A pointer to an array of 10 integers
  g) int (*a)(int); // A pointer to a function a that takes an integer argument and returns an integer
  h) int (*a[10])(int); // An array of 10 pointers to functions that take an integer argument and return an integer

Monday, February 1, 2010

pointer arithmentic

a[99]={.....}
short int* p = a;
short int** q = &p;

p++;//this means that pointer position increase one so that a[0] become a[1]
(*p)++;//this means that the value the pointer is pointing to increase one.


(*q)++;//means pointer p add 1 position so a[1] move to a[2]

(**q)++//means value of pointer q pointing to add one so the value the pointer p point to add 1

Sunday, January 24, 2010

svn command on linux

1.svn --help
List Subversion commands
2.svn help command Also: ? or h
Help on given "command"
3.svn add filename
svn add directory
Add a file or directory to Subversion CM control.
Must also perform: svn ci filename (or svn commit) to upload the file or directory. File will not be available in the repository until a "commit" is performed. If adding a directory, the directory and all of its contents recursively are added. i.e.:
svn ci directory
svn commit directory
svn commit .
4.svn cleanup
Cleanup subversion files resulting from escaped processes and crashed.
5.svn commit filename
svn commit --message "Message goes here." filename
svn commit -m "Message goes here." filename
svn ci filename1 filename2 filename3
svn ci .
Check-in (commit) local "working" file, files or directory and contents (recursively) into Subversion repository. Atomic, i.e. all committed or none, no incomplete check-in.
6.svn diff filename
svn di filename
Show file diffs between SVN repository and your file changes using GNU file diff format. Use GUI diff tools as shown below.

Saturday, January 16, 2010

Review for previous class

Prefix increment vs Postfix increment
int main(){
int a=0;
int b=0;
int c=0;
c = a++ + 36;//c will be 36 a will be 1. a is 0 and when this operation finish a get //added
printf("%d",c);
}

int main(){
int a=0;
int b=0;
int c=0;
c = ++a + 36;//c will be 37 a will be 1. before operation a get added and affect //result
printf("%d",c);
}